refactor: move readwise files to it's own binary
This commit is contained in:
parent
b31502fb37
commit
2827193fd6
6 changed files with 105 additions and 73 deletions
42
Cargo.lock
generated
42
Cargo.lock
generated
|
|
@ -279,6 +279,27 @@ version = "0.7.4"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "f46ad14479a25103f283c0f10005961cf086d8dc42205bb44c46ac563475dca6"
|
checksum = "f46ad14479a25103f283c0f10005961cf086d8dc42205bb44c46ac563475dca6"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "cli"
|
||||||
|
version = "0.1.0"
|
||||||
|
dependencies = [
|
||||||
|
"chrono",
|
||||||
|
"clap",
|
||||||
|
"directories",
|
||||||
|
"figment",
|
||||||
|
"futures",
|
||||||
|
"lib_sync_core",
|
||||||
|
"serde",
|
||||||
|
"serde_json",
|
||||||
|
"sqlx",
|
||||||
|
"tabled",
|
||||||
|
"thiserror",
|
||||||
|
"tokio",
|
||||||
|
"tracing",
|
||||||
|
"tracing-core",
|
||||||
|
"tracing-subscriber",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "colorchoice"
|
name = "colorchoice"
|
||||||
version = "1.0.3"
|
version = "1.0.3"
|
||||||
|
|
@ -1341,27 +1362,6 @@ dependencies = [
|
||||||
"getrandom 0.2.16",
|
"getrandom 0.2.16",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "readwise-bulk-upload"
|
|
||||||
version = "0.1.0"
|
|
||||||
dependencies = [
|
|
||||||
"chrono",
|
|
||||||
"clap",
|
|
||||||
"directories",
|
|
||||||
"figment",
|
|
||||||
"futures",
|
|
||||||
"lib_sync_core",
|
|
||||||
"serde",
|
|
||||||
"serde_json",
|
|
||||||
"sqlx",
|
|
||||||
"tabled",
|
|
||||||
"thiserror",
|
|
||||||
"tokio",
|
|
||||||
"tracing",
|
|
||||||
"tracing-core",
|
|
||||||
"tracing-subscriber",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "redox_syscall"
|
name = "redox_syscall"
|
||||||
version = "0.5.12"
|
version = "0.5.12"
|
||||||
|
|
|
||||||
|
|
@ -1,8 +1,12 @@
|
||||||
[package]
|
[package]
|
||||||
name = "readwise-bulk-upload"
|
name = "cli"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
edition = "2024"
|
edition = "2024"
|
||||||
|
|
||||||
|
[[bin]]
|
||||||
|
name = "readwise"
|
||||||
|
path = "bin/readwise/main.rs"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
lib_sync_core = {path = "../lib_sync_core"}
|
lib_sync_core = {path = "../lib_sync_core"}
|
||||||
|
|
||||||
|
|
|
||||||
76
cli/bin/readwise/main.rs
Normal file
76
cli/bin/readwise/main.rs
Normal file
|
|
@ -0,0 +1,76 @@
|
||||||
|
use clap::{CommandFactory, Parser};
|
||||||
|
use directories::ProjectDirs;
|
||||||
|
use figment::{
|
||||||
|
Figment,
|
||||||
|
providers::{Env, Serialized},
|
||||||
|
};
|
||||||
|
use lib_sync_core::task_manager::{TaskManager, TaskStatus};
|
||||||
|
use cli::config::{Command, Config};
|
||||||
|
use cli::{Error, Result};
|
||||||
|
use std::fs::File;
|
||||||
|
use tabled::Table;
|
||||||
|
use tracing_subscriber;
|
||||||
|
use crate::external_interface::DocumentPayload;
|
||||||
|
|
||||||
|
mod external_interface;
|
||||||
|
|
||||||
|
#[tokio::main]
|
||||||
|
async fn main() -> Result<()> {
|
||||||
|
let cli = Config::parse();
|
||||||
|
let args: Config = Figment::new()
|
||||||
|
.merge(Serialized::defaults(&cli))
|
||||||
|
.merge(Env::prefixed("APP_"))
|
||||||
|
.extract()?;
|
||||||
|
|
||||||
|
tracing_subscriber::fmt()
|
||||||
|
.with_max_level(args.log_level())
|
||||||
|
.init();
|
||||||
|
|
||||||
|
run(&cli.command).await?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
async fn run(command: &Command) -> Result<()> {
|
||||||
|
let project_dir = ProjectDirs::from("", "", "synchronizator_readwise").ok_or(
|
||||||
|
lib_sync_core::error::Error::Unhandled("Could not get standard directories"),
|
||||||
|
)?;
|
||||||
|
|
||||||
|
let task_manager = TaskManager::new(project_dir.data_dir()).await?;
|
||||||
|
|
||||||
|
match command {
|
||||||
|
Command::LoadTasks { path } => {
|
||||||
|
let file = File::open(path).map_err(|_| {
|
||||||
|
Error::Runtime(format!(
|
||||||
|
r#"The file "{}" could not be open"#,
|
||||||
|
path.display()
|
||||||
|
))
|
||||||
|
})?;
|
||||||
|
|
||||||
|
let documents: Vec<DocumentPayload> = serde_json::from_reader(file)?;
|
||||||
|
|
||||||
|
task_manager.load_tasks(documents).await?;
|
||||||
|
}
|
||||||
|
Command::Query => {
|
||||||
|
let tasks = task_manager
|
||||||
|
.get_tasks::<DocumentPayload>(None, Some(25))
|
||||||
|
.await?;
|
||||||
|
|
||||||
|
println!("{}", Table::new(tasks));
|
||||||
|
}
|
||||||
|
Command::Run => {
|
||||||
|
task_manager
|
||||||
|
.run_tasks::<DocumentPayload>(|task| {
|
||||||
|
println!("{}", task.get_key());
|
||||||
|
|
||||||
|
TaskStatus::Completed
|
||||||
|
})
|
||||||
|
.await?;
|
||||||
|
}
|
||||||
|
Command::None => {
|
||||||
|
Config::command().print_help()?;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
@ -1,5 +1,4 @@
|
||||||
pub mod config;
|
pub mod config;
|
||||||
pub mod readwise;
|
|
||||||
mod error;
|
mod error;
|
||||||
|
|
||||||
pub use error::*;
|
pub use error::*;
|
||||||
|
|
@ -1,15 +1,10 @@
|
||||||
use clap::{CommandFactory, Parser};
|
use clap::Parser;
|
||||||
use figment::{
|
use figment::{
|
||||||
providers::{Env, Serialized},
|
providers::{Env, Serialized},
|
||||||
Figment,
|
Figment,
|
||||||
};
|
};
|
||||||
use readwise_bulk_upload::config::{Command, Config};
|
use cli::config::Config;
|
||||||
use readwise_bulk_upload::readwise::DocumentPayload;
|
use cli::Result;
|
||||||
use lib_sync_core::task_manager::{TaskManager, TaskStatus};
|
|
||||||
use readwise_bulk_upload::{Error, Result};
|
|
||||||
use std::fs::File;
|
|
||||||
use directories::ProjectDirs;
|
|
||||||
use tabled::Table;
|
|
||||||
use tracing_subscriber;
|
use tracing_subscriber;
|
||||||
|
|
||||||
#[tokio::main]
|
#[tokio::main]
|
||||||
|
|
@ -24,47 +19,5 @@ async fn main() -> Result<()> {
|
||||||
.with_max_level(args.log_level())
|
.with_max_level(args.log_level())
|
||||||
.init();
|
.init();
|
||||||
|
|
||||||
run(&cli.command).await?;
|
|
||||||
|
|
||||||
Ok(())
|
|
||||||
}
|
|
||||||
|
|
||||||
async fn run(command: &Command) -> Result<()> {
|
|
||||||
let project_dir = ProjectDirs::from("", "", env!("CARGO_PKG_NAME"))
|
|
||||||
.ok_or(lib_sync_core::error::Error::Unhandled("Could not get standard directories"))?;
|
|
||||||
|
|
||||||
let task_manager = TaskManager::new(project_dir.data_dir()).await?;
|
|
||||||
|
|
||||||
match command {
|
|
||||||
Command::LoadTasks { path } => {
|
|
||||||
let file = File::open(path).map_err(|_| {
|
|
||||||
Error::Runtime(format!(
|
|
||||||
r#"The file "{}" could not be open"#,
|
|
||||||
path.display()
|
|
||||||
))
|
|
||||||
})?;
|
|
||||||
|
|
||||||
let documents: Vec<DocumentPayload> = serde_json::from_reader(file)?;
|
|
||||||
|
|
||||||
|
|
||||||
task_manager.load_tasks(documents).await?;
|
|
||||||
}
|
|
||||||
Command::Query => {
|
|
||||||
let tasks = task_manager.get_tasks::<DocumentPayload>(None, Some(25)).await?;
|
|
||||||
|
|
||||||
println!("{}", Table::new(tasks));
|
|
||||||
}
|
|
||||||
Command::Run => {
|
|
||||||
task_manager.run_tasks::<DocumentPayload>(|task| {
|
|
||||||
println!("{}", task.get_key());
|
|
||||||
|
|
||||||
TaskStatus::Completed
|
|
||||||
}).await?;
|
|
||||||
}
|
|
||||||
Command::None => {
|
|
||||||
Config::command().print_help()?;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue