From 084646e21b4ef5ed8abb7a89a44fb03e8ea0e9c8 Mon Sep 17 00:00:00 2001 From: Sasha Hilton Date: Sun, 25 Feb 2018 05:40:00 +0100 Subject: [PATCH] Use prompt for password in main.rs --- core/src/authentication.rs | 12 +++++------- src/main.rs | 10 +++++++++- 2 files changed, 14 insertions(+), 8 deletions(-) diff --git a/core/src/authentication.rs b/core/src/authentication.rs index c079d543..2946f477 100644 --- a/core/src/authentication.rs +++ b/core/src/authentication.rs @@ -7,11 +7,11 @@ use crypto::hmac::Hmac; use crypto::pbkdf2::pbkdf2; use crypto::sha1::Sha1; use protobuf::ProtobufEnum; -use rpassword; use serde; use serde_json; use std::fs::File; -use std::io::{self, stderr, Read, Write}; +use std::io::{self, Read, Write}; +use std::ops::FnOnce; use std::path::Path; use protocol::authentication::AuthenticationType; @@ -180,10 +180,11 @@ where base64::decode(&v).map_err(|e| serde::de::Error::custom(e.to_string())) } -pub fn get_credentials( +pub fn get_credentials String>( username: Option, password: Option, cached_credentials: Option, + prompt: F, ) -> Option { match (username, password, cached_credentials) { (Some(username), Some(password), _) => Some(Credentials::with_password(username, password)), @@ -193,10 +194,7 @@ pub fn get_credentials( } (Some(username), None, _) => { - write!(stderr(), "Password for {}: ", username).unwrap(); - stderr().flush().unwrap(); - let password = rpassword::read_password().unwrap(); - Some(Credentials::with_password(username.clone(), password)) + Some(Credentials::with_password(username.clone(), prompt(&username))) } (None, _, Some(credentials)) => Some(credentials), diff --git a/src/main.rs b/src/main.rs index a42be82d..e3adc498 100644 --- a/src/main.rs +++ b/src/main.rs @@ -3,6 +3,7 @@ extern crate env_logger; extern crate futures; extern crate getopts; extern crate librespot; +extern crate rpassword; extern crate tokio_core; extern crate tokio_io; extern crate tokio_signal; @@ -177,10 +178,17 @@ fn setup(args: &[String]) -> Setup { let credentials = { let cached_credentials = cache.as_ref().and_then(Cache::credentials); + let password = |username: &String| -> String { + write!(stderr(), "Password for {}: ", username).unwrap(); + stderr().flush().unwrap(); + rpassword::read_password().unwrap() + }; + get_credentials( matches.opt_str("username"), matches.opt_str("password"), - cached_credentials + cached_credentials, + password ) };