1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
use std::collections::HashSet;
use database::ReadTransaction;
use hash::Blake2bHash;
use hash::Hash;
use keys::Address;
use tree_primitives::accounts_proof::AccountsProof;
use transaction::TransactionsProof;
use utils::merkle::Blake2bMerkleProof;
use crate::Blockchain;
impl<'env> Blockchain<'env> {
pub fn get_transactions_proof(&self, block_hash: &Blake2bHash, addresses: &HashSet<Address>) -> Option<TransactionsProof> {
let block = self.get_block(block_hash, false, true)?;
let body = block.body.as_ref()?;
let mut matches = Vec::new();
for transaction in body.transactions.iter() {
if addresses.contains(&transaction.sender) || addresses.contains(&transaction.recipient) {
matches.push(transaction.clone());
}
}
let merkle_leaves = body.get_merkle_leaves::<Blake2bHash>();
let matching_hashes: Vec<Blake2bHash> = matches.iter().map(Hash::hash).collect();
let proof = Blake2bMerkleProof::new(merkle_leaves, matching_hashes);
Some(TransactionsProof {
transactions: matches,
proof,
})
}
pub fn get_accounts_proof(&self, block_hash: &Blake2bHash, addresses: &[Address]) -> Option<AccountsProof> {
let state = self.state.read();
if block_hash != &state.head_hash {
return None;
}
let txn = ReadTransaction::new(self.env);
Some(state.accounts.get_accounts_proof(&txn, addresses))
}
}