Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: implement anvil_metadata/anvil_nodeInfo API endpoints #422

Open
itegulov opened this issue Nov 25, 2024 · 2 comments
Open

feat: implement anvil_metadata/anvil_nodeInfo API endpoints #422

itegulov opened this issue Nov 25, 2024 · 2 comments

Comments

@itegulov
Copy link
Contributor

itegulov commented Nov 25, 2024

We need to decide on our metadata/node info format, likely something close to anvil + some potential ZKsync-specific stuff.

#[rpc(name = "anvil_metadata")]
fn metadata(&self) -> RpcResult<Metadata>;

#[rpc(name = "anvil_nodeInfo")]
fn node_info(&self) -> RpcResult<NodeInfo>;
@itegulov itegulov changed the title feat: implement anvil_metadata API endpoint feat: implement anvil_metadata/anvil_nodeInfo API endpoints Nov 25, 2024
@itegulov
Copy link
Contributor Author

anvil_metadata

Anvil inherited anvil_metadata as an alias to hardhat_metadata and they kept compatibility with their format:

pub struct Metadata {
    /// client version
    pub client_version: String,
    /// Chain id of the node.
    pub chain_id: ChainId,
    /// Unique instance id
    pub instance_id: B256,
    /// Latest block number
    pub latest_block_number: u64,
    /// Latest block hash
    pub latest_block_hash: BlockHash,
    /// Forked network info
    pub forked_network: Option<ForkedNetwork>,
    /// Snapshots of the chain
    pub snapshots: BTreeMap<U256, (u64, B256)>,
}

We could either respect it as is too or add extra ZKsync-specific fields on top (latest batch number and fork batch number come to mind).

anvil_nodeInfo

AFAICT anvil_nodeInfo is anvil-specific and looks like this:

pub struct NodeInfo {
    /// The current block number
    pub current_block_number: u64,
    /// The current block timestamp
    pub current_block_timestamp: u64,
    /// The current block hash
    pub current_block_hash: BlockHash,
    /// The enabled hardfork
    pub hard_fork: String,
    /// How transactions are ordered for mining
    pub transaction_order: String,
    /// Info about the node's block environment
    pub environment: NodeEnvironment,
    /// Info about the node's fork configuration
    pub fork_config: NodeForkConfig,
}

pub struct NodeEnvironment {
    /// Base fee of the current block
    pub base_fee: U256,
    /// Chain id of the node.
    pub chain_id: ChainId,
    /// Configured block gas limit
    pub gas_limit: U256,
    /// Configured gas price
    pub gas_price: U256,
}

pub struct NodeForkConfig {
    /// URL of the forked network
    pub fork_url: Option<String>,
    /// Block number of the forked network
    pub fork_block_number: Option<u64>,
    /// Retry backoff for requests
    pub fork_retry_backoff: Option<u128>,
}

Similar situation here wrt our options but the difference here would be bigger due to our fee structure being completely different.

If we decide to keep complete compatibility with both then we will still have an option to add our own endpoint with control over response format.

@dutterbutter @popzxc WDYT?

@popzxc
Copy link
Member

popzxc commented Dec 5, 2024

I think it's fine to extend the response (we already do that in other APIs)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants