use clap::Args;
use colorful::Colorful;
use console::Term;
use ockam::Context;
use crate::terminal::tui::DeleteCommandTui;
use crate::util::node_rpc;
use crate::{docs, fmt_ok, fmt_warn, CommandGlobalOpts, Terminal, TerminalStream};
const LONG_ABOUT: &str = include_str!("./static/delete/long_about.txt");
const AFTER_LONG_HELP: &str = include_str!("./static/delete/after_long_help.txt");
#[derive(Clone, Debug, Args)]
#[command(
long_about = docs::about(LONG_ABOUT),
after_long_help = docs::after_help(AFTER_LONG_HELP)
)]
pub struct DeleteCommand {
name: Option<String>,
#[arg(display_order = 901, long, short)]
yes: bool,
#[arg(long, short)]
all: bool,
}
impl DeleteCommand {
pub fn run(self, options: CommandGlobalOpts) {
node_rpc(run_impl, (options, self))
}
}
pub struct DeleteTui {
opts: CommandGlobalOpts,
cmd: DeleteCommand,
}
impl DeleteTui {
pub async fn run(opts: CommandGlobalOpts, cmd: DeleteCommand) -> miette::Result<()> {
let tui = Self { opts, cmd };
tui.delete().await
}
}
async fn run_impl(
_ctx: Context,
(opts, cmd): (CommandGlobalOpts, DeleteCommand),
) -> miette::Result<()> {
DeleteTui::run(opts, cmd).await
}
#[ockam_core::async_trait]
impl DeleteCommandTui for DeleteTui {
const ITEM_NAME: &'static str = "identity";
fn cmd_arg_item_name(&self) -> Option<&str> {
self.cmd.name.as_deref()
}
fn cmd_arg_delete_all(&self) -> bool {
self.cmd.all
}
fn cmd_arg_confirm_deletion(&self) -> bool {
self.cmd.yes
}
fn terminal(&self) -> Terminal<TerminalStream<Term>> {
self.opts.terminal.clone()
}
async fn get_arg_item_name_or_default(&self) -> miette::Result<String> {
Ok(self
.opts
.state
.get_named_identity_or_default(&self.cmd.name)
.await?
.name())
}
async fn list_items_names(&self) -> miette::Result<Vec<String>> {
Ok(self
.opts
.state
.get_named_identities()
.await?
.iter()
.map(|i| i.name())
.collect())
}
async fn delete_single(&self, item_name: &str) -> miette::Result<()> {
let state = &self.opts.state;
state.delete_identity_by_name(item_name).await?;
self.terminal()
.stdout()
.plain(fmt_ok!(
"The identity named '{}' has been deleted",
item_name
))
.machine(item_name)
.json(serde_json::json!({ "name": item_name }))
.write_line()?;
Ok(())
}
async fn delete_multiple(&self, selected_items_names: Vec<String>) -> miette::Result<()> {
let mut plain = String::new();
for name in selected_items_names {
if self
.opts
.state
.delete_identity_by_name(name.as_ref())
.await
.is_ok()
{
plain.push_str(&fmt_ok!("Identity '{name}' deleted\n"))
} else {
plain.push_str(&fmt_warn!("Failed to delete identity '{name}'\n"))
}
}
self.terminal().stdout().plain(plain).write_line()?;
Ok(())
}
}