chore: chall, chall-config
This commit is contained in:
@@ -12,7 +12,7 @@ impl Command for CommandImpl {
|
||||
fn name(&self) -> &str { "chall" }
|
||||
|
||||
fn subcommand<'a>(&self) -> App<'a, 'a> {
|
||||
SubCommand::with_name(self.name()).about("Yubikey challenge-response hmac")
|
||||
SubCommand::with_name(self.name()).about("YubiKey challenge-response HMAC")
|
||||
.arg(Arg::with_name("challenge").short("c").long("challenge").takes_value(true).help("Challenge"))
|
||||
.arg(Arg::with_name("challenge-hex").short("x").long("challenge-hex").takes_value(true).help("Challenge HEX"))
|
||||
.arg(Arg::with_name("sha256").short("2").long("sha256").help("Output SHA256"))
|
||||
@@ -28,14 +28,13 @@ impl Command for CommandImpl {
|
||||
let sha256_output = sub_arg_matches.is_present("sha256");
|
||||
let sha384_output = sub_arg_matches.is_present("sha384");
|
||||
let sha512_output = sub_arg_matches.is_present("sha512");
|
||||
let challenge_bytes: Vec<u8>;
|
||||
if let Some(challenge) = sub_arg_matches.value_of("challenge") {
|
||||
challenge_bytes = challenge.as_bytes().to_vec();
|
||||
let challenge_bytes: Vec<u8> = if let Some(challenge) = sub_arg_matches.value_of("challenge") {
|
||||
challenge.as_bytes().to_vec()
|
||||
} else if let Some(challenge_hex) = sub_arg_matches.value_of("challenge-hex") {
|
||||
challenge_bytes = opt_result!(hex::decode(challenge_hex), "Decode challenge hex: {}, failed: {}", challenge_hex);
|
||||
opt_result!(hex::decode(challenge_hex), "Decode challenge hex: {}, failed: {}", challenge_hex)
|
||||
} else {
|
||||
return simple_error!("Challenge must assigned");
|
||||
}
|
||||
};
|
||||
|
||||
// Challenge can not be greater than 64 bytes
|
||||
if challenge_bytes.len() > 64 {
|
||||
@@ -81,7 +80,7 @@ impl Command for CommandImpl {
|
||||
hex_sha512.map(|hex_sha512| success!("Response SHA512 HEX: {}", hex::encode(hex_sha512)));
|
||||
}
|
||||
} else {
|
||||
warning!("Yubikey not found");
|
||||
warning!("YubiKey not found");
|
||||
}
|
||||
|
||||
Ok(None)
|
||||
|
||||
Reference in New Issue
Block a user