Compare commits

..

No commits in common. "3794c4d17545afca24999b7dd15e69ba4453d5c2" and "5350b380e287951afd143d8954fdac76413f81a0" have entirely different histories.

View File

@ -1,7 +1,7 @@
use std::time::{SystemTime, UNIX_EPOCH};
use base32::Alphabet;
use clap::{Parser, Subcommand};
use clap::Parser;
use totp_rfc6238::{HashAlgorithm, TotpGenerator};
/// Get the current time since epoch
@ -14,18 +14,6 @@ pub fn time() -> u64 {
#[derive(Parser, Debug)]
#[clap(author, version, about, long_about = None)]
struct Args {
#[clap(subcommand)]
command: SubCommands
}
#[derive(Subcommand, Debug)]
enum SubCommands {
/// Setup configuration
Setup,
/// Get a TOTP code
#[clap(arg_required_else_help = true)]
Code {
/// The secret to use
#[clap(short, long)]
secret: String,
@ -37,34 +25,20 @@ enum SubCommands {
/// Size of generated secret
#[clap(short, long, default_value_t = 6)]
len: usize,
},
}
fn main() {
let args: Args = Args::parse();
match args.command {
SubCommands::Setup => {
println!("To configure TOPT :");
println!("1. Please open https://mysignins.microsoft.com/security-info");
println!("2. Click on \"Add method\"");
println!("3. On the popup that appears, choose \"Authenticator app\" and click \"Add\".");
println!("4. Click on \"I want to use a different authenticator app\" and click \"Next\"");
println!("5. Click on \"Can't save image ?\" and copy the \"Secret key\"");
println!("6. Re-run this program running {} code --secret <SECRET>", std::env::args().next().unwrap());
println!("7. Back on the browser, click Next and paste copied code");
}
SubCommands::Code { secret, topt_step, len } => {
let totp_generator = TotpGenerator::new()
.set_digit(len).unwrap()
.set_step(topt_step).unwrap()
.set_digit(args.len).unwrap()
.set_step(args.topt_step).unwrap()
.set_hash_algorithm(HashAlgorithm::SHA1)
.build();
let key = base32::decode(
Alphabet::RFC4648 { padding: true },
&secret,
&args.secret,
).unwrap();
let code = totp_generator.get_code(&key);
@ -72,6 +46,4 @@ fn main() {
println!("Secret = {}", code);
println!("Next update = {} seconds", next_update - time());
}
}
}