Skip to content

Commit

Permalink
fix: fix get_storage_proof
Browse files Browse the repository at this point in the history
The storage proofs were being returned out of order,
and certain use cases of the endpoint where there are no
storage keys but the root was still needed were not implemented.
  • Loading branch information
GMKrieger committed Jan 21, 2025
1 parent f3edbd7 commit f73935b
Showing 1 changed file with 13 additions and 15 deletions.
28 changes: 13 additions & 15 deletions crates/rpc/src/method/get_storage_proof.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,3 @@
use std::collections::HashSet;

use anyhow::Context;
use pathfinder_common::trie::TrieNode;
use pathfinder_common::{
Expand Down Expand Up @@ -378,7 +376,7 @@ fn get_class_proofs(
node_hash,
node: ProofNode(node),
})
.collect::<HashSet<_>>()
.collect::<Vec<_>>()
.into_iter()
.collect();
let classes_proof = NodeHashToNodeMappings(nodes);
Expand Down Expand Up @@ -423,7 +421,7 @@ fn get_contract_proofs(
node_hash,
node: ProofNode(node),
})
.collect::<HashSet<_>>()
.collect::<Vec<_>>()
.into_iter()
.collect();

Expand Down Expand Up @@ -476,24 +474,24 @@ fn get_contract_storage_proofs(
.context("Querying contract root index")?;

if let Some(root) = root {
let nodes: Vec<NodeHashToNodeMapping> = ContractsStorageTree::get_proofs(
ContractsStorageTree::get_proofs(
&tx,
csk.contract_address,
block_number,
&csk.storage_keys,
root,
)?
.into_iter()
.flatten()
.map(|(node, node_hash)| NodeHashToNodeMapping {
node_hash,
node: ProofNode(node),
})
.collect::<HashSet<_>>()
.into_iter()
.collect();

proofs.push(NodeHashToNodeMappings(nodes));
.for_each(|vec_nodes| {
let nodes = vec_nodes
.into_iter()
.map(|(node, node_hash)| NodeHashToNodeMapping {
node_hash,
node: ProofNode(node),
})
.collect::<Vec<_>>();
proofs.push(NodeHashToNodeMappings(nodes));
});
} else {
proofs.push(NodeHashToNodeMappings(vec![]));
}
Expand Down

0 comments on commit f73935b

Please sign in to comment.