Expand description
§password-worker 
A module providing a password hashing and verification worker.
This module contains the PasswordWorker
struct, which manages hashing and verification
operations using a combination of a rayon
thread pool and crossbeam-channel
to efficiently
handle these operations asynchronously. It also makes use of a tokio::sync::oneshot
channel
but does not require the tokio runtime to be present.
The methods will not block the async runtime. All await operations do not block. They use non-blocking channel implementations to send and receive passwords and hashes to the rayon thread pool.
PasswordWorker
is Send + Sync + Clone
, and contains no lifetimes. The Clone implementation
is a shallow copy that “points” to the same thread pool. It can be used as shared state without
an Arc. All methods take &self
so a Mutex
is also not necessary.
§Add as Dependency
cargo add password-worker
## OR if you want to also add argon2 support
cargo add password-worker -F rust-argon2
§Example
use password_worker::{BcryptConfig, PasswordWorker};
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
let password = "hunter2";
let cost = 12; // bcrypt cost value
let max_threads = 4; // rayon thread pool max threads
let password_worker = PasswordWorker::new_bcrypt(max_threads)?;
let hashed_password = password_worker.hash(password, BcryptConfig { cost }).await?;
println!("Hashed password: {:?}", hashed_password);
let is_valid = password_worker.verify(password, hashed_password).await?;
println!("Verification result: {:?}", is_valid);
Ok(())
}
§Available feature flags
There are some implementations included in the library. Each is tied to optional dependency features.
bcrypt
- (default) (dependency), exports the Bcrypt and BcryptConfig types.rust-argon2
- (dependency), exports the Argon2id and Argon2idConfig types.
Structs§
- Argon2id
Config rust-argon2
- The configuration attributes needed to perform argon2id hashing
- Bcrypt
Config bcrypt
- The configuration attributes needed to perform bcrypt hashing
- Password
Worker - A worker that handles password hashing and verification using a
rayon
thread pool andcrossbeam-channel
.
Enums§
- Argon2id
rust-argon2
- Use this type in the generic constructor to use argon2id
- Bcrypt
bcrypt
- Use this type in the generic constructor to use bcrypt
- Password
Worker Error - Errors that can occur in the
PasswordWorker
.
Traits§
- Hasher
- Implement this to use your own hashing algorithm with this library