extern crate anyhow;
extern crate clap;
extern crate rust_pgdatadiff;
use anyhow::Result;
use clap::{Parser, Subcommand};
use rust_pgdatadiff::diff::diff_ops::Differ;
use rust_pgdatadiff::diff::diff_payload::DiffPayload;
#[derive(Parser)]
#[command(author, version, about, long_about = None)]
#[command(propagate_version = true)]
struct Cli {
#[command(subcommand)]
command: Commands,
}
#[derive(Subcommand)]
enum Commands {
#[command(about = "Print the version")]
Version,
Diff {
first_db: String,
second_db: String,
#[arg(long, default_value_t = false, required = false)]
only_tables: bool,
#[arg(long, default_value_t = false, required = false)]
only_sequences: bool,
#[arg(long, default_value_t = false, required = false)]
only_count: bool,
#[arg(long, default_value_t = 10000, required = false)]
chunk_size: i64,
#[arg(long, default_value_t = 0, required = false)]
start_position: i64,
#[arg(long, default_value_t = 100, required = false)]
max_connections: i64,
#[arg(short, long, value_delimiter = ',', num_args = 0.., required = false, conflicts_with = "exclude_tables")]
include_tables: Vec<String>,
#[arg(short, long, value_delimiter = ',', num_args = 0.., required = false, conflicts_with = "include_tables")]
exclude_tables: Vec<String>,
#[arg(long, default_value = "public", required = false)]
schema_name: String,
#[arg(long, default_value_t = false, required = false)]
accept_invalid_certs_first_db: bool,
#[arg(long, default_value_t = false, required = false)]
accept_invalid_certs_second_db: bool,
},
}
#[tokio::main]
async fn main() -> Result<()> {
tracing_subscriber::fmt::init();
let cli = Cli::parse();
match &cli.command {
Commands::Version => {
println!("Version: {}", env!("CARGO_PKG_VERSION"));
Ok(())
}
Commands::Diff {
first_db,
second_db,
only_tables,
only_sequences,
only_count,
chunk_size,
start_position,
max_connections,
include_tables,
exclude_tables,
schema_name,
accept_invalid_certs_first_db,
accept_invalid_certs_second_db,
} => {
let payload = DiffPayload::builder()
.first_db(first_db.clone())
.second_db(second_db.clone())
.only_tables(*only_tables)
.only_sequences(*only_sequences)
.only_count(*only_count)
.chunk_size(*chunk_size)
.start_position(*start_position)
.max_connections(*max_connections)
.include_tables(include_tables.to_vec())
.exclude_tables(exclude_tables.to_vec())
.schema_name(schema_name.clone())
.accept_invalid_certs_first_db(*accept_invalid_certs_first_db)
.accept_invalid_certs_second_db(*accept_invalid_certs_second_db)
.build();
let _ = Differ::diff_dbs(payload).await;
Ok(())
}
}
}