mirror of
https://github.com/status-im/c-kzg-4844.git
synced 2025-01-11 10:44:23 +00:00
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:
parent
50bf358c6d
commit
9fbe40a5eb
@ -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
|
||||||
|
Loading…
x
Reference in New Issue
Block a user