musket 0.15.1

Musket is a command line interface to send a URL to several destinations.
Documentation
mod cli;
mod commands;
mod config;
mod destinations;
mod errors;

use clap::Parser;
use cli::{Cli, Command, Destinations};
use commands::*;
use errors::*;

pub async fn run() -> Result<Vec<String>, MusketError> {
    let mut success_messages: Vec<String> = vec![];
    let cli = Cli::parse();

    match cli.cmd {
        Command::Init => match config::configure() {
            Ok(_) => {
                success_messages.push(format!("The configuration file has been created here: \"{}\". \nTo start using Musket, please fill in the configuration file with your data.",
                config::get_configuration_path()
                    .unwrap_or_default()
                    .to_string_lossy()));
            }
            Err(e) => return Err(e.into()),
        },
        Command::Fire {
            url,
            destination,
            tags,
        } => {
            if destination.is_none() {
                return Err(MusketError::Cli {
                    message: format!("The url \"{}\" cannot be sent to a non-existing destination. Set, at least, one valid destination.", url),
                });
            }

            let cfg = config::configure()?;

            let vector_of_tags = tags.unwrap_or_default();
            let destinations = destination.unwrap_or_default();

            for target in destinations {
                match target {
                    Destinations::All => {
                        success_messages.push(bluesky::execute(&cfg, &url, &vector_of_tags).await?);
                        success_messages
                            .push(linkedin::execute(&cfg, &url, &vector_of_tags).await?);
                        success_messages.push(turso::execute(&cfg, &url, &vector_of_tags).await?);
                    }
                    Destinations::Bluesky => {
                        success_messages.push(bluesky::execute(&cfg, &url, &vector_of_tags).await?);
                    }
                    Destinations::LinkedIn => {
                        success_messages
                            .push(linkedin::execute(&cfg, &url, &vector_of_tags).await?);
                    }
                    Destinations::Turso => {
                        success_messages.push(turso::execute(&cfg, &url, &vector_of_tags).await?);
                    }
                }
            }
        }
    }
    Ok(success_messages)
}