Skip to content

Commit

Permalink
Cleanup output
Browse files Browse the repository at this point in the history
  • Loading branch information
jfecher committed Feb 21, 2023
1 parent 4dfdd03 commit fdbc2df
Show file tree
Hide file tree
Showing 3 changed files with 34 additions and 32 deletions.
15 changes: 9 additions & 6 deletions crates/nargo/src/cli/prove_cmd.rs
Original file line number Diff line number Diff line change
Expand Up @@ -109,12 +109,15 @@ pub fn prove_with_path<P: AsRef<Path>>(
backend.prove_with_pk(compiled_program.circuit.clone(), solved_witness, proving_key);

if check_proof {
let valid_proof =
verify_proof(compiled_program, public_inputs, return_value, &proof, verification_key)?;

if !valid_proof {
return Err(CliError::Generic("Could not verify generated proof".to_owned()));
}
let no_proof_name = "".into();
verify_proof(
compiled_program,
public_inputs,
return_value,
&proof,
verification_key,
no_proof_name,
)?;
}

let proof_path = if let Some(proof_name) = proof_name {
Expand Down
47 changes: 23 additions & 24 deletions crates/nargo/src/cli/verify_cmd.rs
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,10 @@ use clap::Args;
use noirc_abi::input_parser::{Format, InputValue};
use noirc_abi::MAIN_RETURN_NAME;
use noirc_driver::CompiledProgram;
use std::{collections::BTreeMap, path::Path};
use std::{
collections::BTreeMap,
path::{Path, PathBuf},
};

/// Given a proof and a program, verify whether the proof is valid
#[derive(Debug, Clone, Args)]
Expand All @@ -33,37 +36,29 @@ pub(crate) fn run(args: VerifyCommand, config: NargoConfig) -> Result<(), CliErr
proof_path.push(Path::new(&args.proof));
proof_path.set_extension(PROOF_EXT);

let circuit_build_path = if let Some(circuit_name) = args.circuit_name {
let circuit_build_path = args.circuit_name.map(|circuit_name| {
let mut circuit_build_path = config.program_dir.clone();
circuit_build_path.push(TARGET_DIR);
circuit_build_path.push(circuit_name);
Some(circuit_build_path)
} else {
None
};
circuit_build_path
});

let result = verify_with_path(
verify_with_path(
config.program_dir,
proof_path.clone(),
circuit_build_path,
false,
args.allow_warnings,
)?;

if !result {
return Err(CliError::ProvingFailed(proof_path));
}

Ok(())
)
}

pub fn verify_with_path<P: AsRef<Path>>(
fn verify_with_path<P: AsRef<Path>>(
program_dir: P,
proof_path: P,
proof_path: PathBuf,
circuit_build_path: Option<P>,
show_ssa: bool,
allow_warnings: bool,
) -> Result<bool, CliError> {
) -> Result<(), CliError> {
let compiled_program = compile_circuit(program_dir.as_ref(), show_ssa, allow_warnings)?;
let (_, verification_key) =
fetch_pk_and_vk(&compiled_program.circuit, circuit_build_path, false, true)?;
Expand All @@ -80,15 +75,14 @@ pub fn verify_with_path<P: AsRef<Path>>(
(BTreeMap::new(), None)
};

let valid_proof = verify_proof(
verify_proof(
compiled_program,
public_inputs_map,
return_value,
&load_hex_data(proof_path)?,
&load_hex_data(&proof_path)?,
verification_key,
)?;

Ok(valid_proof)
proof_path,
)
}

pub(crate) fn verify_proof(
Expand All @@ -97,7 +91,8 @@ pub(crate) fn verify_proof(
return_value: Option<InputValue>,
proof: &[u8],
verification_key: Vec<u8>,
) -> Result<bool, CliError> {
proof_name: PathBuf,
) -> Result<(), CliError> {
let public_abi = compiled_program.abi.public_abi();
let public_inputs = public_abi.encode(&public_inputs_map, return_value)?;

Expand All @@ -111,5 +106,9 @@ pub(crate) fn verify_proof(
verification_key,
);

Ok(valid_proof)
if valid_proof {
Ok(())
} else {
Err(CliError::InvalidProof(proof_name))
}
}
4 changes: 2 additions & 2 deletions crates/nargo/src/errors.rs
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,8 @@ pub enum CliError {
MissingVerificationkey(PathBuf),
#[error("Error: the circuit you are trying to prove differs from the build artifact at {}\nYou must call `nargo compile` to generate the correct proving and verification keys for this circuit", .0.display())]
MismatchedAcir(PathBuf),
#[error("Failed to prove {}", .0.display())]
ProvingFailed(PathBuf),
#[error("Failed to verify proof {}", .0.display())]
InvalidProof(PathBuf),
}

impl From<OpcodeResolutionError> for CliError {
Expand Down

0 comments on commit fdbc2df

Please sign in to comment.