1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
|
use dsa::{Components, KeySize, SigningKey};
use pkcs8::{EncodePrivateKey, EncodePublicKey, LineEnding};
use std::{fs::File, io::Write};
fn main() {
let mut rng = rand::thread_rng();
let components = Components::generate(&mut rng, KeySize::DSA_2048_256);
let signing_key = SigningKey::generate(&mut rng, components);
let verifying_key = signing_key.verifying_key();
let signing_key_bytes = signing_key.to_pkcs8_pem(LineEnding::LF).unwrap();
let verifying_key_bytes = verifying_key.to_public_key_pem(LineEnding::LF).unwrap();
let mut file = File::create("public.pem").unwrap();
file.write_all(verifying_key_bytes.as_bytes()).unwrap();
file.flush().unwrap();
let mut file = File::create("private.pem").unwrap();
file.write_all(signing_key_bytes.as_bytes()).unwrap();
file.flush().unwrap();
}
|