refactor: Improved error handling using ? operator and better function signatures

This commit is contained in:
Kiril Kovachev 2025-05-08 00:08:35 +01:00
parent c5beab75d5
commit 6229d9d5a8

View File

@ -38,36 +38,32 @@ enum Action {
}, },
} }
fn setup() -> Result<(), &'static str> { fn setup() -> Result<(), std::io::Error> {
if let Ok(config_template) = std::fs::read_to_string("mwbot.toml") { if let Ok(config_template) = std::fs::read_to_string("mwbot.toml") {
let username = env::var("MW_USERNAME").expect("The .env file must have a \"MW_USERNAME\" attribute."); let username = env::var("MW_USERNAME").expect("The .env file must have a \"MW_USERNAME\" attribute.");
let oauth2_token = env::var("MW_OAUTH2").expect("The .env file must have a \"MW_OAUTH2\" attribute."); let oauth2_token = env::var("MW_OAUTH2").expect("The .env file must have a \"MW_OAUTH2\" attribute.");
let botpassword = env::var("MW_BOTPASSWORD").expect("The .env file must have a \"MW_BOTPASSWORD\" attribute."); let botpassword: String = env::var("MW_BOTPASSWORD").expect("The .env file must have a \"MW_BOTPASSWORD\" attribute.");
let filled_in_config = formatx!(config_template, username, botpassword, oauth2_token).unwrap(); let filled_in_config = formatx!(config_template, username, botpassword, oauth2_token).unwrap();
std::fs::write(shellexpand::tilde("~/.config/mwbot.toml").into_owned(), filled_in_config).unwrap(); std::fs::write(shellexpand::tilde("~/.config/mwbot.toml").into_owned(), filled_in_config).unwrap();
Ok(()) Ok(())
} else { } else {
Err("Unable to find mwbot.toml; did you execute the script from the same directory?") Err(std::io::Error::new(std::io::ErrorKind::NotFound, "Unable to find mwbot.toml; did you execute the script from the same directory?"))
} }
} }
#[tokio::main] #[tokio::main]
async fn main() { async fn main() -> Result<(), std::io::Error> {
dotenvy::dotenv().expect("Couldn't load .env file; please make sure to create one in the same directory as executing from!"); dotenvy::dotenv().expect("Couldn't load .env file; please make sure to create one in the same directory as executing from!");
let cli = Cli::parse(); let cli = Cli::parse();
match cli.action { match cli.action {
Action::Setup => { Action::Setup => {
if let Err(err) = setup() { setup()?;
eprintln!("{}", err); eprintln!("Successfully set up ~/.config/mwbot.toml.")
exit(1);
} else {
eprintln!("Successfully set up ~/.config/mwbot.toml.");
}
}, },
Action::Run {username, botpassword, oauth2_token, api_url, rest_url} => { Action::Run {username, botpassword, oauth2_token, api_url, rest_url} => {
let bot = mwbot::Bot::builder(api_url, rest_url) let bot = mwbot::Bot::builder(api_url, rest_url)
@ -80,4 +76,5 @@ async fn main() {
println!("{:?}", html.as_nodes()); println!("{:?}", html.as_nodes());
} }
} }
Ok(())
} }