blob: 5a2300dd888445cf9427302b9e8026dbafbc546f [file] [log] [blame]
extern crate security_framework;
#[cfg(target_os = "mac_os")]
use security_framework::os::macos::keychain::SecKeychain;
#[cfg(target_os = "mac_os")]
use security_framework::os::macos::passwords::*;
fn main() {
#[cfg(target_os = "mac_os")] {
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);
}
}
}}