use clap::Args;
use tracing::info;
use openstack_sdk::AsyncOpenStack;
use crate::Cli;
use crate::OpenStackCliError;
use crate::output::OutputProcessor;
use openstack_sdk::api::QueryAsync;
use openstack_sdk::api::block_storage::v3::cluster::list_detailed;
use openstack_types::block_storage::v3::cluster::response::list_detailed::ClusterResponse;
#[derive(Args)]
pub struct ClustersCommand {
#[command(flatten)]
query: QueryParameters,
#[command(flatten)]
path: PathParameters,
}
#[derive(Args)]
struct QueryParameters {
#[arg(help_heading = "Query parameters", long)]
active_backend_id: Option<String>,
#[arg(help_heading = "Query parameters", long, value_parser = ["cinder-api","cinder-backup","cinder-scheduler","cinder-volume"])]
binary: Option<String>,
#[arg(action=clap::ArgAction::Set, help_heading = "Query parameters", long)]
disabled: Option<bool>,
#[arg(action=clap::ArgAction::Set, help_heading = "Query parameters", long)]
frozen: Option<bool>,
#[arg(action=clap::ArgAction::Set, help_heading = "Query parameters", long)]
is_up: Option<bool>,
#[arg(help_heading = "Query parameters", long)]
name: Option<String>,
#[arg(help_heading = "Query parameters", long)]
num_down_hosts: Option<f32>,
#[arg(help_heading = "Query parameters", long)]
num_hosts: Option<f32>,
#[arg(help_heading = "Query parameters", long, value_parser = ["disabled","enabled"])]
replication_stats: Option<String>,
}
#[derive(Args)]
struct PathParameters {}
impl ClustersCommand {
pub async fn take_action(
&self,
parsed_args: &Cli,
client: &mut AsyncOpenStack,
) -> Result<(), OpenStackCliError> {
info!("List Clusters");
let op =
OutputProcessor::from_args(parsed_args, Some("block-storage.cluster"), Some("list"));
op.validate_args(parsed_args)?;
let mut ep_builder = list_detailed::Request::builder();
if let Some(val) = &self.query.active_backend_id {
ep_builder.active_backend_id(val);
}
if let Some(val) = &self.query.binary {
ep_builder.binary(val);
}
if let Some(val) = &self.query.disabled {
ep_builder.disabled(*val);
}
if let Some(val) = &self.query.frozen {
ep_builder.frozen(*val);
}
if let Some(val) = &self.query.is_up {
ep_builder.is_up(*val);
}
if let Some(val) = &self.query.name {
ep_builder.name(val);
}
if let Some(val) = &self.query.num_down_hosts {
ep_builder.num_down_hosts(*val);
}
if let Some(val) = &self.query.num_hosts {
ep_builder.num_hosts(*val);
}
if let Some(val) = &self.query.replication_stats {
ep_builder.replication_stats(val);
}
let ep = ep_builder
.build()
.map_err(|x| OpenStackCliError::EndpointBuild(x.to_string()))?;
let data: Vec<serde_json::Value> = ep.query_async(client).await?;
op.output_list::<ClusterResponse>(data)?;
op.show_command_hint()?;
Ok(())
}
}