Crates.io | libpwquality |
lib.rs | libpwquality |
version | 0.6.1 |
source | src |
created_at | 2023-03-29 10:39:57.101131 |
updated_at | 2023-07-23 14:40:11.849669 |
description | libpwquality bindings for Rust |
homepage | |
repository | https://github.com/nibon7/libpwquality-rs |
max_upload_size | |
id | 823987 |
size | 30,139 |
cargo add libpwquality
libpwquality-rs links system libpwquality library by default, you can
optionally enable vendored
feature and install cracklib dictionaries
to build libpwquality. When the vendored
feature is enabled, you can
export DEFAULT_CRACKLIB_DICT
environment variable to specify the path
of the dictionaries if you encounter problems with the dictionary path.
cargo add libpwquality --features vendored
sudo apt-get install cracklib-runtime
use libpwquality::{PWQError, PWQuality};
fn main() -> Result<(), PWQError> {
let pwq = PWQuality::new()?;
pwq.read_default_config()?
.min_length(9)
.max_repeat(2)
.bad_words(["bad", "password"])?;
let minlen = pwq.get_min_length();
println!("minlen={}", minlen);
let badwords = pwq.get_bad_words()?;
println!("badwords={:?}", badwords);
let maxrepeat = pwq.get_max_repeat();
println!("maxrepeat={}", maxrepeat);
let password = pwq.generate(32)?;
println!("password={:?}", password);
let score = pwq.check(&password, Some("password!"), None)?;
println!("score={}", score);
Ok(())
}