8 releases (4 breaking)

0.5.0 Apr 30, 2021
0.4.0 Dec 10, 2020
0.3.0 Nov 23, 2020
0.2.1 Jun 20, 2020
0.1.1 Mar 30, 2018

#1971 in Cryptography

Download history 690/week @ 2024-07-23 641/week @ 2024-07-30 741/week @ 2024-08-06 770/week @ 2024-08-13 713/week @ 2024-08-20 742/week @ 2024-08-27 670/week @ 2024-09-03 1088/week @ 2024-09-10 981/week @ 2024-09-17 1065/week @ 2024-09-24 1379/week @ 2024-10-01 1262/week @ 2024-10-08 1487/week @ 2024-10-15 1191/week @ 2024-10-22 710/week @ 2024-10-29 1416/week @ 2024-11-05

4,986 downloads per month
Used in 5 crates (via check-if-email-exists)

MIT/Apache

12KB
142 lines

Crates.io Build Status MIT licensed Apache-2.0 licensed

pwned-rs

Check your passwords against Have I been pwned?

Usage

Add this to your Cargo.toml

[dependencies]
pwned = { git = "https://github.com/wisespace-io/pwned-rs.git" }

Check a password against the API and see the number of occurrences

It uses the range API, so only the first 5 characters of a SHA1 hashed password are sent to Have I been pwned?

use pwned::api::*;

#[tokio::main]
async fn main() {
    let pwned = PwnedBuilder::default()
        .build().unwrap();

    match pwned.check_password("password").await {
        Ok(pwd) => println!("Pwned? {} - Occurrences {}", pwd.found, pwd.count),
        Err(e) => println!("Error: {}", e),
    }
}

Check all breaches for an account

use pwned::api::*;
#[tokio::main]
async fn main() {
    
    let pwned = PwnedBuilder::default()
        .user_agent("my_user_agent")
        .api_key(std::env::var("HIBP_API_KEY").expect("You need to give your HIBP API key as the HIBP_API_KEY environment variable"))
        .build().unwrap();

    match pwned.check_email("test@wisespace.io").await {
        Ok(answer) => {
            for breach in answer {
                println!("Service {:?}, breach date {:?} Domain: {:?}", breach.name, breach.breach_date, breach.domain);
            }
        },
        Err(e) => println!("Message: {}", e),
    }

}

Dependencies

~5–17MB
~229K SLoC