From 6b3be4438e2154843c6d7a0670be038b4b87ce8b Mon Sep 17 00:00:00 2001 From: Oskar Thoren Date: Fri, 18 Mar 2022 14:42:38 +0800 Subject: [PATCH] refactor(rln): move out json spike to separate fn --- rln/src/public.rs | 39 ++++++++++++++++++++++++++++++++++----- 1 file changed, 34 insertions(+), 5 deletions(-) diff --git a/rln/src/public.rs b/rln/src/public.rs index 3af09bc..238a99c 100644 --- a/rln/src/public.rs +++ b/rln/src/public.rs @@ -51,15 +51,43 @@ struct WitnessInput { rln_identifier: String, } -// TODO Isolate hardcoded JSON test here // TODO Expand API to have better coverage of things needed impl RLN { - // TODO Break this apart here + // TODO Update this to use new protocol pub fn new() -> RLN { let cfg = CircomConfig::::new("./resources/rln.wasm", "./resources/rln.r1cs").unwrap(); + let mut builder = CircomBuilder::new(cfg); + + // create an empty instance for setting it up + let circom = builder.setup(); + + let mut rng = thread_rng(); + let params = generate_random_parameters::(circom, &mut rng).unwrap(); + + let circom = builder.build().unwrap(); + + let inputs = circom.get_public_inputs().unwrap(); + println!("Public inputs {:#?} ", inputs); + + const LEAF: Hash = Hash::from_bytes_be([0u8; 32]); + let mut tree = PoseidonTree::new(21, LEAF); + + RLN { + circom, + params, + tree, + } + } + + // XXX This is a tempory hack to get end to end proving/verification working + // Not supposed to be part of public API + pub fn new_json_spike() -> RLN { + let cfg = + CircomConfig::::new("./resources/rln.wasm", "./resources/rln.r1cs").unwrap(); + // TODO Refactor // From rln JSON witness // Input generated with https://github.com/oskarth/zk-kit/commit/b6a872f7160c7c14e10a0ea40acab99cbb23c9a8 @@ -238,18 +266,19 @@ impl Default for RLN { #[ignore] #[test] fn rln_proof() { - let mul = RLN::new(); + let rln = RLN::new(); + let rln_spike = RLN::new_json_spike(); //let inputs = mul.circom.get_public_inputs().unwrap(); let mut output_data: Vec = Vec::new(); - let _ = mul.prove(&mut output_data); + let _ = rln_spike.prove(&mut output_data); let proof_data = &output_data[..]; // XXX Pass as arg? //let pvk = prepare_verifying_key(&mul.params.vk); - let verified = mul.verify(proof_data).unwrap(); + let verified = rln.verify(proof_data).unwrap(); assert!(verified); }