A random number generator for generating large prime numbers, suitable for cryptography.
glass_pumpkin
is a cryptographically-secure, random number generator, useful for generating large prime numbers.
This library was inspired by pumpkin except its meant to be used with rust stable.
It also lowers the 512-bit restriction to 128 bits so these can be generated and used for elliptic curve prime fields.
It exposes the prime testing functions as well.
This crate uses num-bigint instead of ramp
.
Add the following to your Cargo.toml
file:
toml
glass-pumpkin = "0.2"
```rust extern crate glass_pumpkin;
use glass_pumpkin::prime;
fn main() { let p = prime::new(1024); let q = prime::new(1024);
let n = p * q;
println!("{}", n);
} ```
You can also supply OsRng
and generate primes from that.
```
extern crate glass_pumpkin;
extern crate rand;
use glass_pumpkin::prime;
use rand::rngs::OsRng; use rand::thread_rng;
fn main() { let mut rng = OsRng::new().unwrap(); let p = prime::fromrng(1024, &mut rng); let q = prime::fromrng(1024, &mut rng);
let n = p * q;
println!("{}", n);
} ```
Primes
are generated similarly to OpenSSL except it applies some recommendations from the Prime and Prejudice paper:
Safe primes require (n-1)/2 also be prime.
You can use this crate to check numbers for primality. ``` extern crate glasspumpkin; extern crate numbigint;
use glasspumpkin::prime; use glasspumpkin::safeprime; use numbigint::BigUint;
fn main() {
if prime::check(BigUint::from(5)) {
println!("is prime");
}
if safe_prime::check(BigUint::from(7)) {
println!("is safe prime");
}
} ```