diff options
| author | Robin Krahl <robin.krahl@ireas.org> | 2019-01-07 22:21:27 +0000 | 
|---|---|---|
| committer | Robin Krahl <me@robin-krahl.de> | 2019-01-11 04:36:55 +0100 | 
| commit | 5ede9c31db245cc3c3354d9c16200545fa5255db (patch) | |
| tree | bb38ef7a7d653a8d866f2fc0a00bfab3bab35eda | |
| parent | 516ee5886f7ddcd60670aa5bdb2edc98cbec257d (diff) | |
| download | nitrocli-otp-qr-5ede9c31db245cc3c3354d9c16200545fa5255db.tar.gz nitrocli-otp-qr-5ede9c31db245cc3c3354d9c16200545fa5255db.tar.bz2 | |
Implement name query using dialog crate
| -rw-r--r-- | Cargo.lock | 43 | ||||
| -rw-r--r-- | Cargo.toml | 1 | ||||
| -rw-r--r-- | src/main.rs | 43 | 
3 files changed, 86 insertions, 1 deletions
| @@ -9,6 +9,14 @@ version = "1.0.4"  source = "registry+https://github.com/rust-lang/crates.io-index"  [[package]] +name = "dialog" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +dependencies = [ + "rpassword 2.1.0 (registry+https://github.com/rust-lang/crates.io-index)", +] + +[[package]]  name = "fuchsia-zircon"  version = "0.3.3"  source = "registry+https://github.com/rust-lang/crates.io-index" @@ -33,6 +41,15 @@ dependencies = [  ]  [[package]] +name = "kernel32-sys" +version = "0.2.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +dependencies = [ + "winapi 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)", + "winapi-build 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)", +] + +[[package]]  name = "libc"  version = "0.2.46"  source = "registry+https://github.com/rust-lang/crates.io-index" @@ -55,6 +72,7 @@ name = "nitrocli-otp-qr"  version = "0.1.0"  dependencies = [   "argparse 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", + "dialog 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)",   "mktemp 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)",   "percent-encoding 1.0.1 (registry+https://github.com/rust-lang/crates.io-index)",   "url 1.7.2 (registry+https://github.com/rust-lang/crates.io-index)", @@ -86,6 +104,16 @@ dependencies = [  ]  [[package]] +name = "rpassword" +version = "2.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +dependencies = [ + "kernel32-sys 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", + "libc 0.2.46 (registry+https://github.com/rust-lang/crates.io-index)", + "winapi 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)", +] + +[[package]]  name = "rustc-serialize"  version = "0.3.24"  source = "registry+https://github.com/rust-lang/crates.io-index" @@ -124,6 +152,11 @@ dependencies = [  [[package]]  name = "winapi" +version = "0.2.8" +source = "registry+https://github.com/rust-lang/crates.io-index" + +[[package]] +name = "winapi"  version = "0.3.6"  source = "registry+https://github.com/rust-lang/crates.io-index"  dependencies = [ @@ -132,6 +165,11 @@ dependencies = [  ]  [[package]] +name = "winapi-build" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" + +[[package]]  name = "winapi-i686-pc-windows-gnu"  version = "0.4.0"  source = "registry+https://github.com/rust-lang/crates.io-index" @@ -144,20 +182,25 @@ source = "registry+https://github.com/rust-lang/crates.io-index"  [metadata]  "checksum argparse 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)" = "3f8ebf5827e4ac4fd5946560e6a99776ea73b596d80898f357007317a7141e47"  "checksum bitflags 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)" = "228047a76f468627ca71776ecdebd732a3423081fcf5125585bcd7c49886ce12" +"checksum dialog 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)" = "5f6585f6d9f6ecf615d3ec6d7fd6b1d06906514ff0c1b5af73830d9157c192f6"  "checksum fuchsia-zircon 0.3.3 (registry+https://github.com/rust-lang/crates.io-index)" = "2e9763c69ebaae630ba35f74888db465e49e259ba1bc0eda7d06f4a067615d82"  "checksum fuchsia-zircon-sys 0.3.3 (registry+https://github.com/rust-lang/crates.io-index)" = "3dcaa9ae7725d12cdb85b3ad99a434db70b468c09ded17e012d86b5c1010f7a7"  "checksum idna 0.1.5 (registry+https://github.com/rust-lang/crates.io-index)" = "38f09e0f0b1fb55fdee1f17470ad800da77af5186a1a76c026b679358b7e844e" +"checksum kernel32-sys 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)" = "7507624b29483431c0ba2d82aece8ca6cdba9382bff4ddd0f7490560c056098d"  "checksum libc 0.2.46 (registry+https://github.com/rust-lang/crates.io-index)" = "023a4cd09b2ff695f9734c1934145a315594b7986398496841c7031a5a1bbdbd"  "checksum matches 0.1.8 (registry+https://github.com/rust-lang/crates.io-index)" = "7ffc5c5338469d4d3ea17d269fa8ea3512ad247247c30bd2df69e68309ed0a08"  "checksum mktemp 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)" = "77001ceb9eed65439f3dc2a2543f9ba1417d912686bf224a7738d0966e6dcd69"  "checksum percent-encoding 1.0.1 (registry+https://github.com/rust-lang/crates.io-index)" = "31010dd2e1ac33d5b46a5b413495239882813e0369f8ed8a5e266f173602f831"  "checksum rand 0.3.22 (registry+https://github.com/rust-lang/crates.io-index)" = "15a732abf9d20f0ad8eeb6f909bf6868722d9a06e1e50802b6a70351f40b4eb1"  "checksum rand 0.4.3 (registry+https://github.com/rust-lang/crates.io-index)" = "8356f47b32624fef5b3301c1be97e5944ecdd595409cc5da11d05f211db6cfbd" +"checksum rpassword 2.1.0 (registry+https://github.com/rust-lang/crates.io-index)" = "d37473170aedbe66ffa3ad3726939ba677d83c646ad4fd99e5b4bc38712f45ec"  "checksum rustc-serialize 0.3.24 (registry+https://github.com/rust-lang/crates.io-index)" = "dcf128d1287d2ea9d80910b5f1120d0b8eede3fbf1abe91c40d39ea7d51e6fda"  "checksum unicode-bidi 0.3.4 (registry+https://github.com/rust-lang/crates.io-index)" = "49f2bd0c6468a8230e1db229cff8029217cf623c767ea5d60bfbd42729ea54d5"  "checksum unicode-normalization 0.1.7 (registry+https://github.com/rust-lang/crates.io-index)" = "6a0180bc61fc5a987082bfa111f4cc95c4caff7f9799f3e46df09163a937aa25"  "checksum url 1.7.2 (registry+https://github.com/rust-lang/crates.io-index)" = "dd4e7c0d531266369519a4aa4f399d748bd37043b00bde1e4ff1f60a120b355a"  "checksum uuid 0.1.18 (registry+https://github.com/rust-lang/crates.io-index)" = "78c590b5bd79ed10aad8fb75f078a59d8db445af6c743e55c4a53227fc01c13f" +"checksum winapi 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)" = "167dc9d6949a9b857f3451275e911c3f44255842c1f7a76f33c55103a909087a"  "checksum winapi 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)" = "92c1eb33641e276cfa214a0522acad57be5c56b10cb348b3c5117db75f3ac4b0" +"checksum winapi-build 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "2d315eee3b34aca4797b2da6b13ed88266e6d612562a0c46390af8299fc699bc"  "checksum winapi-i686-pc-windows-gnu 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)" = "ac3b87c63620426dd9b991e5ce0329eff545bccbbb34f3be09ff6fb6ab51b7b6"  "checksum winapi-x86_64-pc-windows-gnu 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)" = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" @@ -11,6 +11,7 @@ license = "MIT"  [dependencies]  argparse = "0.2" +dialog = "0.2"  mktemp = "0.3"  percent-encoding = "1.0"  url = "1.7" diff --git a/src/main.rs b/src/main.rs index 9fa1a72..331e22f 100644 --- a/src/main.rs +++ b/src/main.rs @@ -1,3 +1,6 @@ +// Copyright (C) 2019 Robin Krahl <robin.krahl@ireas.org> +// SPDX-License-Identifier: MIT +  #![warn(missing_docs, rust_2018_compatibility, rust_2018_idioms, unused)]  //! Reads OTP configuration from a QR code and writes it to an OTP slot on a Nitrokey device. @@ -10,8 +13,11 @@ use std::path;  use std::process;  use std::str; +use dialog::DialogBox; +  #[derive(Debug)]  enum Error { +    DialogError(dialog::Error),      IoError(io::Error),      Error(String),      UrlParseError(url::ParseError), @@ -21,6 +27,7 @@ enum Error {  impl fmt::Display for Error {      fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {          match *self { +            Error::DialogError(ref err) => write!(f, "Dialog error: {:?}", err),              Error::IoError(ref err) => write!(f, "IO error: {}", err),              Error::Error(ref string) => write!(f, "Error: {}", string),              Error::UrlParseError(ref err) => write!(f, "URL parse error: {}", err), @@ -35,6 +42,12 @@ impl From<&str> for Error {      }  } +impl From<dialog::Error> for Error { +    fn from(error: dialog::Error) -> Error { +        Error::DialogError(error) +    } +} +  impl From<io::Error> for Error {      fn from(error: io::Error) -> Error {          Error::IoError(error) @@ -211,6 +224,30 @@ fn parse_url(url: &str) -> Result<UrlData, Error> {      }  } +fn query_name(label: &str, issuer: Option<&str>) -> Result<String, Error> { +    let title = "Enter OTP slot name"; +    let mut text = "Please enter a name for the OTP secret:".to_string(); +    text.push_str(&format!("\n\tlabel:\t{}", label)); +    if let Some(issuer) = issuer { +        text.push_str(&format!("\n\tissuer:\t{}", issuer)); +    }; +    let text = text; +    let default = issuer.unwrap_or(label); +    let name = dialog::Input::new(text) +        .title(title) +        .default(default) +        .show()?; +    if let Some(name) = name { +        if name.is_empty() { +            Err(Error::from("The OTP name may not be empty")) +        } else { +            Ok(name.trim_end_matches(&"\n").to_string()) +        } +    } else { +        Err(Error::from("You canceled the name input dialog")) +    } +} +  fn run(options: Options) -> Result<(), Error> {      let path = match options.file {          Some(ref file) => path::PathBuf::from(file), @@ -218,7 +255,11 @@ fn run(options: Options) -> Result<(), Error> {      };      let url = decode_qr_code(&path)?;      let url_data = parse_url(&url)?; -    println!("{:?}", url_data); +    let name = match options.name { +        Some(name) => name, +        None => query_name(&url_data.label, url_data.issuer.as_ref().map(|x| &**x))?, +    }; +    println!("{}: {:?}", name, url_data);      if options.file.is_none() {          fs::remove_file(&path)?;      } | 
