-
Notifications
You must be signed in to change notification settings - Fork 1.3k
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(rpc): add eth_multicallV1
#5596
Changes from all commits
dabb7f9
6fd5f41
5b9576d
2b00e72
0254a2a
82a9260
4fa89ca
85ba521
5c8adf0
40e2910
7dc3db7
a4cefc5
6e5f3d7
3e09c8a
f566782
b7fd137
9367198
aab37ee
d238126
3b8deba
d1b7f51
f9d2f99
80d27e8
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
@@ -40,6 +40,16 @@ where | |||||||||||||
BlockReaderIdExt + ChainSpecProvider + StateProviderFactory + EvmEnvProvider + 'static, | ||||||||||||||
Network: NetworkInfo + Send + Sync + 'static, | ||||||||||||||
{ | ||||||||||||||
/// Executes complex RPC calls to Ethereum nodes | ||||||||||||||
|
||||||||||||||
pub async fn eth_multicall_v1( | ||||||||||||||
Comment on lines
+43
to
+45
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
|
||||||||||||||
&self, | ||||||||||||||
multicall_bundle: Bundle, | ||||||||||||||
state_context: Option<StateContext>, | ||||||||||||||
state_override: Option<StateOverride>, | ||||||||||||||
) -> EthResult<Vec<EthCallResponse>> { | ||||||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. this is just the same as call_many? so atm we don't need this function and can reuse call_many instead There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
hey ty for your review, you means i should directly call the function call_many inside this function ? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. yes, at least for now There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
ty so much, very greatful from your part all these review. should be fine now |
||||||||||||||
EthApi::call_many(self, multicall_bundle, state_context, state_override).await | ||||||||||||||
} | ||||||||||||||
/// Estimate gas needed for execution of the `request` at the [BlockId]. | ||||||||||||||
pub async fn estimate_gas_at(&self, request: CallRequest, at: BlockId) -> EthResult<U256> { | ||||||||||||||
let (cfg, block_env, at) = self.evm_env_at(at).await?; | ||||||||||||||
|
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
|
@@ -51,6 +51,17 @@ where | |||||
EthApiSpec::protocol_version(self).await.to_rpc_result() | ||||||
} | ||||||
|
||||||
/// Handler for ! `eth_MultiCallV1` | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
|
||||||
async fn eth_multicall_v1( | ||||||
&self, | ||||||
multi_call: Bundle, | ||||||
state_context: Option<StateContext>, | ||||||
state_override: Option<StateOverride>, | ||||||
) -> Result<Vec<EthCallResponse>> { | ||||||
trace!(target: "rpc::eth", "Serving eth_multicall_v1 request"); | ||||||
Ok(EthApi::eth_multicall_v1(self, multi_call, state_context, state_override).await?) | ||||||
} | ||||||
|
||||||
/// Handler for: `eth_syncing` | ||||||
fn syncing(&self) -> Result<SyncStatus> { | ||||||
trace!(target: "rpc::eth", "Serving eth_syncing"); | ||||||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
jsonrpc method names are case sensitive and eth prefix is already specified on the trait