ockam_command 0.104.0

End-to-end encryption and mutual authentication for distributed applications.
Documentation
use crate::util::local_cmd;
use crate::vault::util::VaultOutput;
use crate::{docs, CommandGlobalOpts};
use clap::Args;
use miette::IntoDiagnostic;
use ockam_api::cli_state::traits::StateDirTrait;

const LONG_ABOUT: &str = include_str!("./static/list/long_about.txt");
const PREVIEW_TAG: &str = include_str!("../static/preview_tag.txt");
const AFTER_LONG_HELP: &str = include_str!("./static/list/after_long_help.txt");

/// List vaults
#[derive(Clone, Debug, Args)]
#[command(
    long_about = docs::about(LONG_ABOUT),
    before_help = docs::before_help(PREVIEW_TAG),
    after_long_help = docs::after_help(AFTER_LONG_HELP)
)]
pub struct ListCommand;

impl ListCommand {
    pub fn run(self, opts: CommandGlobalOpts) {
        local_cmd(run_impl(opts));
    }
}

fn run_impl(opts: CommandGlobalOpts) -> miette::Result<()> {
    let vaults = opts
        .state
        .vaults
        .list()?
        .into_iter()
        .map(|v| VaultOutput::new(&v, opts.state.vaults.is_default(v.name()).unwrap_or(false)))
        .collect::<Vec<_>>();
    let plain = opts
        .terminal
        .build_list(&vaults, "Vaults", "No Vaults found")?;
    let json = serde_json::to_string(&vaults).into_diagnostic()?;
    opts.terminal
        .stdout()
        .plain(plain)
        .json(json)
        .write_line()?;
    Ok(())
}