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
pub(crate) mod affine;
mod field;
#[cfg(feature = "hash2curve")]
mod hash2curve;
mod mul;
pub(crate) mod projective;
pub(crate) mod scalar;
#[cfg(test)]
mod dev;
pub use field::FieldElement;
use affine::AffinePoint;
use projective::ProjectivePoint;
use scalar::Scalar;
const CURVE_EQUATION_B_SINGLE: u32 = 7u32;
#[rustfmt::skip]
pub(crate) const CURVE_EQUATION_B: FieldElement = FieldElement::from_bytes_unchecked(&[
0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, CURVE_EQUATION_B_SINGLE as u8,
]);
#[cfg(test)]
mod tests {
use super::CURVE_EQUATION_B;
use hex_literal::hex;
const CURVE_EQUATION_B_BYTES: [u8; 32] =
hex!("0000000000000000000000000000000000000000000000000000000000000007");
#[test]
fn verify_constants() {
assert_eq!(CURVE_EQUATION_B.to_bytes(), CURVE_EQUATION_B_BYTES.into());
}
#[test]
fn generate_secret_key() {
use crate::SecretKey;
use elliptic_curve::rand_core::OsRng;
let key = SecretKey::random(&mut OsRng);
assert!(!key.to_be_bytes().iter().all(|b| *b == 0))
}
}