summaryrefslogtreecommitdiffstats
path: root/examples/proofer_blake3.rs
blob: 62d142928ece61934baccac8ae93d2a80670e9a4 (plain)
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
44
45
46
47
48
use mt_rs::{
    hasher::{Blake3Hasher, Hasher},
    node::Node,
    proof::{DefaultProofer, Proofer},
};

fn main() {
    let root_hash = match std::env::args().nth(1) {
        Some(hash) => hash,
        None => {
            eprintln!(
                "Usage: cargo run --example proofer_blake3 -- <root_hash> <file1> <file2> ..."
            );
            std::process::exit(1);
        }
    };

    let filenames: Vec<String> = std::env::args().skip(2).collect();
    if filenames.is_empty() {
        eprintln!("Usage: cargo run --example proofer_blake3 -- <root_hash> <file1> <file2> ...");
        std::process::exit(1);
    }

    let mut nodes: Vec<Node> = Vec::new();
    for filename in &filenames {
        match std::fs::read(filename) {
            Ok(contents) => nodes.push(Node::new_leaf(Blake3Hasher::new().hash(&contents))),
            Err(e) => {
                eprintln!("Failed to read file '{}': {}", filename, e);
                std::process::exit(1);
            }
        }
    }

    let hasher = Blake3Hasher::new();
    let proofer = DefaultProofer::new(&hasher, nodes);
    let proof = proofer.generate(0).expect("Couldn't generate proof");

    println!(
        "{}",
        proofer.verify(
            &proof,
            std::fs::read(&filenames[0]).unwrap(),
            &root_hash[..],
            &hasher
        )
    );
}