trello-to-deck/src/lib.rs

223 lines
5.9 KiB
Rust
Raw Normal View History

//
use std::path::PathBuf;
2024-12-01 07:13:23 +00:00
use clap::Parser;
use color_eyre::eyre::eyre;
pub use config::AppConfig;
2024-12-07 10:05:37 +00:00
use kxio::{fs::FileSystem, net::Net, print::Printer};
mod api_result;
2024-11-29 14:31:40 +00:00
mod check;
2024-11-29 19:19:36 +00:00
mod config;
mod init;
2024-11-29 17:43:49 +00:00
mod macros;
pub mod nextcloud;
mod template;
mod trello;
#[cfg(test)]
mod tests;
2024-11-29 17:43:49 +00:00
2024-11-29 14:31:40 +00:00
pub const NAME: &str = "trello-to-deck";
2024-12-07 10:05:37 +00:00
pub use kxio::kxeprintln as e;
pub use kxio::kxprintln as p;
use nextcloud::DeckClient;
2024-12-07 10:05:37 +00:00
#[derive(Parser, Debug)]
#[clap(version = clap::crate_version!(), author = clap::crate_authors!(), about = clap::crate_description!())]
struct Commands {
2024-12-08 10:51:19 +00:00
#[clap(long, action = clap::ArgAction::SetTrue)]
log: bool,
#[clap(subcommand)]
command: Command,
}
#[derive(Parser, Debug)]
enum Command {
Init,
Check,
Import,
#[clap(subcommand)]
Trello(TrelloCommand),
#[clap(subcommand)]
Nextcloud(NextcloudCommand),
}
#[derive(Parser, Debug)]
enum NextcloudCommand {
#[clap(subcommand)]
Board(NextcloudBoardCommand),
#[clap(subcommand)]
Stack(NextcloudStackCommand),
#[clap(subcommand)]
Card(NextcloudCardCommand),
}
#[derive(Parser, Debug)]
enum NextcloudBoardCommand {
List {
#[clap(long, action = clap::ArgAction::SetTrue)]
dump: bool,
},
}
#[derive(Parser, Debug)]
enum NextcloudStackCommand {
List {
#[clap(long, action = clap::ArgAction::SetTrue)]
dump: bool,
},
}
#[derive(Parser, Debug)]
enum NextcloudCardCommand {
List {
#[clap(long, action = clap::ArgAction::SetTrue)]
dump: bool,
stack_id: i64,
},
Get {
#[clap(long, action = clap::ArgAction::SetTrue)]
dump: bool,
stack_id: i64,
card_id: i64,
},
Create {
#[clap(long, action = clap::ArgAction::SetTrue)]
dump: bool,
stack_id: i64,
#[clap(long)]
title: String,
#[clap(long)]
description: Option<String>,
},
}
#[derive(Parser, Debug)]
enum TrelloCommand {
#[clap(subcommand)]
Board(TrelloBoardCommand),
}
#[derive(Parser, Debug)]
enum TrelloBoardCommand {
List {
#[clap(long, action = clap::ArgAction::SetTrue)]
dump: bool,
},
}
#[derive(Clone)]
pub struct Ctx {
pub fs: FileSystem,
pub net: Net,
2024-12-07 10:05:37 +00:00
pub prt: Printer,
}
impl Default for Ctx {
fn default() -> Self {
Self {
fs: kxio::fs::new(PathBuf::default()),
net: kxio::net::new(),
2024-12-07 10:05:37 +00:00
prt: kxio::print::standard(),
}
}
}
2024-11-29 14:31:40 +00:00
#[derive(Clone)]
pub struct FullCtx {
pub fs: FileSystem,
pub net: Net,
2024-12-07 10:05:37 +00:00
pub prt: Printer,
pub cfg: AppConfig,
}
impl FullCtx {
pub(crate) fn deck_client(&self) -> DeckClient {
DeckClient::new(self)
}
}
2024-11-29 14:31:40 +00:00
#[cfg_attr(test, mutants::skip)]
pub async fn run(ctx: Ctx) -> color_eyre::Result<()> {
2024-11-29 14:31:40 +00:00
color_eyre::install()?;
let commands = Commands::parse();
2024-12-08 10:51:19 +00:00
if commands.log {
tracing::subscriber::set_global_default(
tracing_subscriber::FmtSubscriber::builder()
.with_max_level(tracing::Level::TRACE)
.finish(),
)?;
tracing::info!("ready");
}
let cfg = AppConfig::load(&ctx);
match cfg {
Err(err) => {
if matches!(commands.command, Command::Init) {
init::run(&ctx)
} else {
Err(eyre!("Missing or invalid config: {err}"))
}
}
Ok(cfg) => {
let ctx = FullCtx {
fs: ctx.fs,
net: ctx.net,
2024-12-07 10:05:37 +00:00
prt: ctx.prt,
cfg,
};
match commands.command {
Command::Init => Err(eyre!("Config file already exists. Not overwriting it.")),
2024-11-29 14:31:40 +00:00
Command::Check => check::run(ctx).await,
Command::Import => todo!("import"),
2024-12-08 07:24:44 +00:00
Command::Trello(trello) => match trello {
TrelloCommand::Board(board) => match board {
TrelloBoardCommand::List { dump } => {
nextcloud::board::list(ctx, dump).await
}
},
},
Command::Nextcloud(nextcloud) => match nextcloud {
NextcloudCommand::Board(board) => match board {
NextcloudBoardCommand::List { dump } => {
nextcloud::board::list(ctx, dump).await
}
},
NextcloudCommand::Stack(stack) => match stack {
NextcloudStackCommand::List { dump } => {
nextcloud::stack::list(ctx, dump).await
}
},
NextcloudCommand::Card(card) => match card {
NextcloudCardCommand::List { dump, stack_id } => {
nextcloud::card::list(ctx, dump, stack_id.into()).await
}
NextcloudCardCommand::Get {
dump,
stack_id,
card_id,
} => nextcloud::card::get(ctx, dump, stack_id.into(), card_id.into()).await,
NextcloudCardCommand::Create {
dump,
stack_id,
title,
description,
} => {
nextcloud::card::create(
ctx,
nextcloud::card::Create {
dump,
stack_id,
title,
description,
},
)
.await
}
2024-12-08 07:24:44 +00:00
},
},
}
}
}
2024-11-29 14:31:40 +00:00
}