- replace panics with proper error handling using `Result` - enhance logging with error source information and initial log message - adjust default log level to Info
72 lines
1.5 KiB
Rust
72 lines
1.5 KiB
Rust
use clap::{Parser, Subcommand};
|
|
|
|
mod list_cli;
|
|
|
|
use cull_gmail::Error;
|
|
use list_cli::ListCli;
|
|
use std::error::Error as stdError;
|
|
|
|
#[derive(Parser, Debug)]
|
|
#[clap(author, version, about, long_about = None)]
|
|
struct Cli {
|
|
#[clap(flatten)]
|
|
logging: clap_verbosity_flag::Verbosity,
|
|
#[command(subcommand)]
|
|
command: Option<Commands>,
|
|
}
|
|
|
|
#[derive(Subcommand, Debug)]
|
|
enum Commands {
|
|
/// List messages
|
|
#[clap(name = "list")]
|
|
List(ListCli),
|
|
}
|
|
|
|
#[tokio::main]
|
|
async fn main() {
|
|
let args = Cli::parse();
|
|
|
|
let mut logging = get_logging(args.logging.log_level_filter());
|
|
logging.init();
|
|
log::info!("Logging started.");
|
|
|
|
match run(args).await {
|
|
Ok(_) => {}
|
|
Err(e) => {
|
|
if let Some(src) = e.source() {
|
|
log::error!("{e}: {src}");
|
|
eprintln!("{e}: {src}");
|
|
} else {
|
|
log::error!("{e}");
|
|
eprintln!("{e}");
|
|
}
|
|
std::process::exit(101);
|
|
}
|
|
}
|
|
}
|
|
|
|
async fn run(args: Cli) -> Result<(), Error> {
|
|
if let Some(cmds) = args.command {
|
|
match cmds {
|
|
Commands::List(list_cli) => list_cli.run("credential.json").await?,
|
|
}
|
|
}
|
|
Ok(())
|
|
}
|
|
|
|
fn get_logging(level: log::LevelFilter) -> env_logger::Builder {
|
|
let level = if level > log::LevelFilter::Info {
|
|
level
|
|
} else {
|
|
log::LevelFilter::Info
|
|
};
|
|
|
|
let mut builder = env_logger::Builder::new();
|
|
|
|
builder.filter(None, level);
|
|
|
|
builder.format_timestamp_secs().format_module_path(false);
|
|
|
|
builder
|
|
}
|