25 lines
666 B
Rust
25 lines
666 B
Rust
|
use crypto::digest::Digest;
|
||
|
use crypto::sha2::Sha256;
|
||
|
use sodiumoxide::crypto::pwhash::argon2id13;
|
||
|
|
||
|
pub fn hash_secret(secret: &str) -> String {
|
||
|
sodiumoxide::init().unwrap();
|
||
|
let hash = argon2id13::pwhash(
|
||
|
secret.as_bytes(),
|
||
|
argon2id13::OPSLIMIT_INTERACTIVE,
|
||
|
argon2id13::MEMLIMIT_INTERACTIVE,
|
||
|
)
|
||
|
.unwrap();
|
||
|
let texthash = std::str::from_utf8(&hash.0).unwrap().to_string();
|
||
|
|
||
|
// postgres hates null chars. don't do that to postgres
|
||
|
texthash.trim_end_matches('\u{0}').to_string()
|
||
|
}
|
||
|
|
||
|
pub fn hash_str(string: &str) -> String {
|
||
|
let mut hasher = Sha256::new();
|
||
|
hasher.input_str(string);
|
||
|
|
||
|
hasher.result_str()
|
||
|
}
|