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

Get Proof implementation #2128

Open
wants to merge 7 commits into
base: main
Choose a base branch
from
Open

Get Proof implementation #2128

wants to merge 7 commits into from

Conversation

bzawisto
Copy link
Contributor

@bzawisto bzawisto commented Jan 10, 2025

This PR introduces eth_getProof implementation.

Copy link
Contributor

github-actions bot commented Jan 10, 2025

🐰 Bencher Report

Branch1547-implement-state-proof
Testbedself-hosted
Click to view all benchmark results
BenchmarkLatencyBenchmark Result
milliseconds (ms)
(Result Δ%)
Upper Boundary
milliseconds (ms)
(Limit %)
process-empty/process-empty📈 view plot
🚷 view threshold
9.37
(+2.22%)
10.34
(90.61%)
produce-full/produce-full📈 view plot
🚷 view threshold
1,952.90
(-1.01%)
2,310.97
(84.51%)
🐰 View full continuous benchmarking report in Bencher

return Ok(Proof::default());
};

// get_proof() requires &mut so clone state and don't mutate the origin
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why not make this &mut self instead? You already make a clone of it in the API implementation (by calling .at_root).

let storage_proofs = {
let mut storage_proofs = Vec::new();
for key in storage_keys {
let key = Self::account_storage_key(address, *key);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@DrZoltanFazekas Are we happy that this exposes our trie encoding as part of our external API (and thus makes it hard to ever change it)?

I ask because I don't think we are encoding things into the trie the same way as Ethereum does and thus there's no guarantee that what we're doing is sensible.

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

Successfully merging this pull request may close these issues.

2 participants