feat(stronghold): add an init function that uses argon2 (#449)
Co-authored-by: Lucas Nogueira <lucas@tauri.studio>pull/542/head
parent
700549ab02
commit
dacde1629d
@ -0,0 +1,5 @@
|
|||||||
|
---
|
||||||
|
"stronghold": patch
|
||||||
|
---
|
||||||
|
|
||||||
|
Added `Builder::with_argon2`.
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,35 @@
|
|||||||
|
use rand_chacha::ChaCha20Rng;
|
||||||
|
use rand_core::{RngCore, SeedableRng};
|
||||||
|
use std::path::Path;
|
||||||
|
|
||||||
|
/// NOTE: Hash supplied to Stronghold must be 32bits long.
|
||||||
|
/// This is a current limitation of Stronghold.
|
||||||
|
const HASH_LENGTH: usize = 32;
|
||||||
|
|
||||||
|
pub struct KeyDerivation {}
|
||||||
|
|
||||||
|
impl KeyDerivation {
|
||||||
|
/// Will create a key from [`password`] and a generated salt.
|
||||||
|
/// Salt will be generated to file [`salt_path`] or taken from it
|
||||||
|
/// if file already exists
|
||||||
|
pub fn argon2(password: &str, salt_path: &Path) -> Vec<u8> {
|
||||||
|
let mut salt = [0u8; HASH_LENGTH];
|
||||||
|
create_or_get_salt(&mut salt, salt_path);
|
||||||
|
|
||||||
|
argon2::hash_raw(password.as_bytes(), &salt, &Default::default())
|
||||||
|
.expect("Failed to generate hash for password")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn create_or_get_salt(salt: &mut [u8], salt_path: &Path) {
|
||||||
|
if salt_path.is_file() {
|
||||||
|
// Get existing salt
|
||||||
|
let tmp = std::fs::read(salt_path).unwrap();
|
||||||
|
salt.clone_from_slice(&tmp);
|
||||||
|
} else {
|
||||||
|
// Generate new salt
|
||||||
|
let mut gen = ChaCha20Rng::from_entropy();
|
||||||
|
gen.fill_bytes(salt);
|
||||||
|
std::fs::write(salt_path, salt).expect("Failed to write salt for Stronghold")
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in new issue