8 releases (breaking)

0.6.0 Nov 3, 2024
0.5.1 Aug 31, 2024
0.5.0 Aug 28, 2021
0.4.0 Aug 3, 2021
0.0.0 Jan 12, 2020

#114 in Authentication

Download history 1685/week @ 2024-09-27 1047/week @ 2024-10-04 1133/week @ 2024-10-11 1376/week @ 2024-10-18 1159/week @ 2024-10-25 2126/week @ 2024-11-01 2125/week @ 2024-11-08 1512/week @ 2024-11-15 919/week @ 2024-11-22 1784/week @ 2024-11-29 1421/week @ 2024-12-06 2572/week @ 2024-12-13 446/week @ 2024-12-20 147/week @ 2024-12-27 1066/week @ 2025-01-03 1137/week @ 2025-01-10

3,220 downloads per month
Used in 15 crates (11 directly)

MIT/Apache

31KB
533 lines

pinentry

pinentry is a library for interacting with the pinentry binaries available on various platforms.

Usage

Add this line to your Cargo.toml:

pinentry = "0.6"

See the documentation for examples.

pinentry requires Rust version 1.60 or greater.

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.


lib.rs:

pinentry is a library for interacting with the pinentry binaries available on various platforms.

Examples

Request passphrase or PIN

use pinentry::PassphraseInput;
use secrecy::SecretString;

let passphrase = if let Some(mut input) = PassphraseInput::with_default_binary() {
    // pinentry binary is available!
    input
        .with_description("Enter new passphrase for FooBar")
        .with_prompt("Passphrase:")
        .with_confirmation("Confirm passphrase:", "Passphrases do not match")
        .interact()
} else {
    // Fall back to some other passphrase entry method.
    Ok("a better passphrase than this".to_owned().into())
}?;

Ask user for confirmation

use pinentry::ConfirmationDialog;

if let Some(mut input) = ConfirmationDialog::with_default_binary() {
    input
        .with_ok("Definitely!")
        .with_not_ok("No thanks")
        .with_cancel("Maybe later")
        .confirm("Would you like to play a game?")?;
};

Display a message

use pinentry::MessageDialog;

if let Some(mut input) = MessageDialog::with_default_binary() {
    input.with_ok("Got it!").show_message("This will be shown with a single button.")?;
};

Dependencies

~2–11MB
~138K SLoC