ockam_command 0.150.0

End-to-end encryption and mutual authentication for distributed applications.
use clap::Args;

use ockam::Context;
use ockam_api::cli_state::random_name;
use ockam_api::nodes::InMemoryNode;
use ockam_api::orchestrator::project::ProjectsOrchestratorApi;

use crate::operation::util::check_for_project_completion;
use crate::project::util::check_project_readiness;
use crate::shared_args::IdentityOpts;
use crate::util::parsers::project_name_parser;
use crate::{docs, CommandGlobalOpts};
use ockam_api::output::Output;

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

/// Create a Project
#[derive(Clone, Debug, Args)]
#[command(
long_about = docs::about(LONG_ABOUT),
after_long_help = docs::after_help(AFTER_LONG_HELP),
)]
pub struct CreateCommand {
    /// Name of the Space the project belongs to.
    #[arg(display_order = 1001)]
    pub space_name: String,

    /// Name of the project - must be unique within parent Space
    #[arg(display_order = 1002, default_value_t = random_name(), hide_default_value = true, value_parser = project_name_parser)]
    pub project_name: String,

    #[command(flatten)]
    pub identity_opts: IdentityOpts,
    //TODO:  list of admins
}

impl CreateCommand {
    pub fn name(&self) -> String {
        "project create".into()
    }

    pub(crate) async fn run(&self, ctx: &Context, opts: CommandGlobalOpts) -> miette::Result<()> {
        let node = InMemoryNode::start(ctx, &opts.state).await?;
        let project = node
            .create_project(ctx, &self.space_name, &self.project_name, vec![])
            .await?;
        let project = check_for_project_completion(&opts, ctx, &node, project).await?;
        let project = check_project_readiness(&opts, ctx, &node, project).await?;
        opts.terminal
            .to_stdout()
            .plain(project.item()?)
            .json(serde_json::json!(&project))
            .write_line()?;
        Ok(())
    }
}