For better maintenance, this project has been deprecated and merged into the ckb-zkp repository.
So DO NOT USE this project, check ckb-zkp for the latest development.
Zero-knowledge proofs toolkit with pure Rust, empowering the community with the cutting-edge techniques of zero-knowledge proofs to develop all kinds of decentralized applications.
The project is going to bridge the gap of cryptographic engineering between thriving academic research and aspiring dAPPs developers, by providing multiple zkp scheme and curve options, a more user-friendly interface, many useful gadget libraries, and many more tutorials and examples.
This project is part of zkp-toolkit-ckb and is supported by the Nervos Foundation. Check out the original proposal and grant announcement.
It can be used in conjunction with the ckb-zkp project to implement on-chain zkp verifiers for the CKB-VM.
Use the MiMC gadget and Groth16 scheme we supported as an example.
use rand::prelude::*;
use zkp::curve::bn_256::{Bn_256, Fr};
use zkp::gadget::mimc::{constants, MiMC};
use zkp::math::ToBytes;
use zkp::scheme::groth16::generate_random_parameters;
use zkp::{prove, prove_to_bytes, verify, verify_from_bytes, Curve, Gadget, Scheme};
/// test for use groth16 & bn_256 & mimc gadget.
fn main() {
let bytes = vec![1, 2, 3, 4, 5]; // this is your secret.
let mut rng = thread_rng();
// TRUSTED SETUP
println!("TRUSTED SETUP...");
let constants = constants::<Fr>();
let c = MiMC::<Fr> {
xl: None,
xr: None,
constants: &constants,
};
let params = generate_random_parameters::<Bn_256, _, _>(c, &mut rng).unwrap();
// you need save this prove key,
// when prove, use it as a params.
let mut pk_bytes = vec![];
params.write(&mut pk_bytes).unwrap();
// you need save this verify key,
// when verify, use it as a params.
let mut vk_bytes = vec![];
params.vk.write(&mut vk_bytes).unwrap();
println!("START PROVE...");
let proof = prove(
Gadget::MiMC(bytes),
Scheme::Groth16,
Curve::Bn_256,
&pk_bytes,
rng,
)
.unwrap();
println!("START VERIFY...");
let is_ok = verify(proof, &vk_bytes);
assert!(is_ok);
}
- Efficient computation.
- Variety of curves.
- Variety of zkp schemes.
- Multiple out-of-the-box gadgets.
no-std
is supported.
Currently, Groth16 and bulletproofs are supported. You can describe zkp circuits for the Groth16 scheme through the powerful constraint system. Specially, we implemented a modified version of bulletproofs with R1CS support. It also supports to describe constraints through the same constraint system. So gadgets could be sharable between Groth16 and bulletproofs. We're working on that.
You can check the original proposal for more feature details.
Check CLI usage for hands-on examples.
- MiMC hash
- GreaterThan
- LessThan
- Between
- Boolean
- ... Many others ...
Check the gadget doc for more details.
This project is still under active development and is currently being used for research and experimental purposes only, please DO NOT USE IT IN PRODUCTION for now.
This project is licensed under either of
- Apache License, Version 2.0, (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.
Inspired by bellman, zexe, libsnark, dalek-bulletproofs and other great projects.