-
Notifications
You must be signed in to change notification settings - Fork 396
Expand file tree
/
Copy pathverifier.rs
More file actions
54 lines (47 loc) · 1.16 KB
/
verifier.rs
File metadata and controls
54 lines (47 loc) · 1.16 KB
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
49
50
51
52
53
54
use aligned_sdk::common::types::ProvingSystemId;
#[derive(Copy, Clone, Debug)]
#[repr(C)]
pub struct ListRef {
data: *const u8,
len: usize,
}
impl From<Vec<u8>> for ListRef {
fn from(v: Vec<u8>) -> Self {
Self::from(v.as_slice())
}
}
impl From<&Vec<u8>> for ListRef {
fn from(v: &Vec<u8>) -> Self {
Self::from(v.as_slice())
}
}
impl From<&[u8]> for ListRef {
fn from(v: &[u8]) -> Self {
let len = v.len();
let data = v.as_ptr().cast();
ListRef { data, len }
}
}
pub fn verify_circom(
proving_system: &ProvingSystemId,
proof: &Vec<u8>,
public_input: &Vec<u8>,
verification_key: &Vec<u8>,
) -> bool {
let proof = proof.into();
let public_input = public_input.into();
let verification_key = verification_key.into();
match proving_system {
ProvingSystemId::CircomGroth16Bn128 => unsafe {
VerifyCircomGroth16ProofBN128(proof, public_input, verification_key)
},
_ => false,
}
}
extern "C" {
pub fn VerifyCircomGroth16ProofBN128(
proof: ListRef,
public_input: ListRef,
verification_key: ListRef,
) -> bool;
}