17 releases
Uses old Rust 2015
0.4.23 | May 22, 2024 |
---|---|
0.4.22 | May 18, 2024 |
0.4.20 | Mar 21, 2022 |
0.4.15 | Jan 18, 2022 |
0.4.10 | Aug 27, 2020 |
#281 in Cryptography
34 downloads per month
Used in rabe
175KB
3K
SLoC
bn
This is a pairing cryptography library written in pure Rust. It makes use of the Barreto-Naehrig (BN) curve construction from [BCTV2015] to provide two cyclic groups G1 and G2, with an efficient bilinear pairing:
e: G1 × G2 → GT
Security warnings
This library, like other pairing cryptography libraries implementing this construction, is not resistant to side-channel attacks.
Usage
Add the bn
crate to your dependencies in Cargo.toml
...
[dependencies]
rabe-bn = "0.4.22"
If you prefer borsh instead of serde
, you may use the borsh
feature.
Afterwards add an extern crate
declaration to your crate root:
extern crate rabe_bn;
API
Fr
is an element of FrG1
is a point on the BN curve E/Fq : y^2 = x^3 + bG2
is a point on the twisted BN curve E'/Fq2 : y^2 = x^3 + b/xiGt
is a group element (written multiplicatively) obtained with thepairing
function overG1
andG2
.
License
Licensed under either of
- MIT license, (LICENSE-MIT or http://opensource.org/licenses/MIT)
- Apache License, Version 2.0 (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
at your option.
Copyright 2016 Zcash Electric Coin Company. The Zcash Company promises to maintain the "bn" crate on crates.io under this MIT/Apache-2.0 dual license.
Authors
Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.
Dependencies
~0.4–1MB
~19K SLoC