security-framework 2.4.0

Security.framework bindings for macOS and iOS
Documentation
#[cfg(target_os = "macos")]
use security_framework::os::macos::keychain::SecKeychain;
#[cfg(target_os = "macos")]
use security_framework::os::macos::passwords::*;

fn main() {
    #[cfg(target_os = "macos")] {
    let hostname = "example.com";
    let username = "rusty";
    let res = SecKeychain::default().unwrap().find_internet_password(
        hostname,
        None,
        username,
        "",
        None,
        SecProtocolType::Any,
        SecAuthenticationType::Any,
    );
    match res {
        Ok((password, _)) => {
            println!(
                "Password for {}@{} is {} bytes long",
                username,
                hostname,
                password.len()
            );
        }
        Err(err) if err.code() == -128 => {
            eprintln!("Account was found in the Keychain, but user denied access");
        }
        Err(err) => {
            eprintln!("Password not found. Open Keychain Access.app and add internet password for '{}' at 'https://{}': {:?}",
                username, hostname, err);
        }
    }
}}