Add length check to verify_aggregate_kzg_proof in rust bindings (#74)

* Add length check to verify_aggregate_kzg_proof in rust bindings

* Generate incorrect blob later

* Remove leftover parenthesis

* Move result var after check
This commit is contained in:
Justin Traglia 2023-01-18 15:44:33 -06:00 committed by GitHub
parent 50bf358c6d
commit 9fbe40a5eb
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -25,6 +25,8 @@ pub enum Error {
InvalidKzgCommitment(String), InvalidKzgCommitment(String),
/// The provided trusted setup is invalid. /// The provided trusted setup is invalid.
InvalidTrustedSetup(String), InvalidTrustedSetup(String),
/// Paired arguments have different lengths.
MismatchLength(String),
/// The underlying c-kzg library returned an error. /// The underlying c-kzg library returned an error.
CError(C_KZG_RET), CError(C_KZG_RET),
} }
@ -154,6 +156,13 @@ impl KZGProof {
expected_kzg_commitments: &[KZGCommitment], expected_kzg_commitments: &[KZGCommitment],
kzg_settings: &KZGSettings, kzg_settings: &KZGSettings,
) -> Result<bool, Error> { ) -> Result<bool, Error> {
if blobs.len() != expected_kzg_commitments.len() {
return Err(Error::MismatchLength(format!(
"There are {} blobs and {} commitments",
blobs.len(),
expected_kzg_commitments.len()
)));
}
let mut verified: MaybeUninit<bool> = MaybeUninit::uninit(); let mut verified: MaybeUninit<bool> = MaybeUninit::uninit();
unsafe { unsafe {
let res = verify_aggregate_kzg_proof( let res = verify_aggregate_kzg_proof(
@ -278,7 +287,7 @@ mod tests {
assert!(trusted_setup_file.exists()); assert!(trusted_setup_file.exists());
let kzg_settings = KZGSettings::load_trusted_setup_file(trusted_setup_file).unwrap(); let kzg_settings = KZGSettings::load_trusted_setup_file(trusted_setup_file).unwrap();
let num_blobs: usize = rng.gen_range(0..16); let num_blobs: usize = rng.gen_range(1..16);
let mut blobs: Vec<Blob> = (0..num_blobs) let mut blobs: Vec<Blob> = (0..num_blobs)
.map(|_| generate_random_blob(&mut rng)) .map(|_| generate_random_blob(&mut rng))
.collect(); .collect();
@ -295,8 +304,14 @@ mod tests {
.verify_aggregate_kzg_proof(&blobs, &kzg_commitments, &kzg_settings) .verify_aggregate_kzg_proof(&blobs, &kzg_commitments, &kzg_settings)
.unwrap()); .unwrap());
let incorrect_blob = generate_random_blob(&mut rng);
blobs.pop(); blobs.pop();
let error = kzg_proof
.verify_aggregate_kzg_proof(&blobs, &kzg_commitments, &kzg_settings)
.unwrap_err();
assert!(matches!(error, Error::MismatchLength(_)));
let incorrect_blob = generate_random_blob(&mut rng);
blobs.push(incorrect_blob); blobs.push(incorrect_blob);
assert!(!kzg_proof assert!(!kzg_proof