Merge pull request #10 from ebfull/small-order-checks

Check epk/rk/cv are not small order
This commit is contained in:
ebfull 2018-05-14 16:26:40 -06:00 committed by GitHub
commit a64c850e6d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 22 additions and 0 deletions

View File

@ -42,6 +42,12 @@ static mut SAPLING_SPEND_PARAMS: Option<Parameters<Bls12>> = None;
static mut SAPLING_OUTPUT_PARAMS: Option<Parameters<Bls12>> = None; static mut SAPLING_OUTPUT_PARAMS: Option<Parameters<Bls12>> = None;
static mut SPROUT_GROTH16_PARAMS_PATH: Option<String> = None; static mut SPROUT_GROTH16_PARAMS_PATH: Option<String> = None;
fn is_small_order<Order>(
p: &edwards::Point<Bls12, Order>
) -> bool {
p.double(&JUBJUB).double(&JUBJUB).double(&JUBJUB) == edwards::Point::zero()
}
/// Writes an FrRepr to [u8] of length 32 /// Writes an FrRepr to [u8] of length 32
fn write_le(mut f: FrRepr, to: &mut [u8]) { fn write_le(mut f: FrRepr, to: &mut [u8]) {
assert_eq!(to.len(), 32); assert_eq!(to.len(), 32);
@ -243,6 +249,10 @@ pub extern "system" fn librustzcash_sapling_check_spend(
Err(_) => return false, Err(_) => return false,
}; };
if is_small_order(&cv) {
return false;
}
// Accumulate the value commitment in the context // Accumulate the value commitment in the context
{ {
let mut tmp = cv.clone(); let mut tmp = cv.clone();
@ -273,6 +283,10 @@ pub extern "system" fn librustzcash_sapling_check_spend(
Err(_) => return false, Err(_) => return false,
}; };
if is_small_order(&rk.0) {
return false;
}
// Deserialize the signature // Deserialize the signature
let spend_auth_sig = match Signature::read(&(unsafe { &*spend_auth_sig })[..]) { let spend_auth_sig = match Signature::read(&(unsafe { &*spend_auth_sig })[..]) {
Ok(sig) => sig, Ok(sig) => sig,
@ -348,6 +362,10 @@ pub extern "system" fn librustzcash_sapling_check_output(
Err(_) => return false, Err(_) => return false,
}; };
if is_small_order(&cv) {
return false;
}
// Accumulate the value commitment in the context // Accumulate the value commitment in the context
{ {
let mut tmp = cv.clone(); let mut tmp = cv.clone();
@ -371,6 +389,10 @@ pub extern "system" fn librustzcash_sapling_check_output(
Err(_) => return false, Err(_) => return false,
}; };
if is_small_order(&epk) {
return false;
}
// Construct public input for circuit // Construct public input for circuit
let mut public_input = [Fr::zero(); 5]; let mut public_input = [Fr::zero(); 5];
{ {