openstack_cli_compute/v2/quota_set/
delete.rs1use clap::Args;
23use eyre::OptionExt;
24use tracing::info;
25
26use openstack_cli_core::cli::CliArgs;
27use openstack_cli_core::error::OpenStackCliError;
28use openstack_cli_core::output::OutputProcessor;
29use openstack_sdk::AsyncOpenStack;
30
31use openstack_sdk::api::QueryAsync;
32use openstack_sdk::api::compute::v2::quota_set::delete;
33use openstack_sdk::api::find_by_name;
34use openstack_sdk::api::identity::v3::user::find as find_user;
35use tracing::warn;
36
37#[derive(Args)]
46#[command(about = "Revert Quotas To Defaults")]
47pub struct QuotaSetCommand {
48 #[command(flatten)]
50 query: QueryParameters,
51
52 #[command(flatten)]
54 path: PathParameters,
55}
56
57#[derive(Args)]
59struct QueryParameters {
60 #[command(flatten)]
62 user: UserInput,
63}
64
65#[derive(Args)]
67#[group(required = false, multiple = false)]
68struct UserInput {
69 #[arg(long, help_heading = "Path parameters", value_name = "USER_NAME")]
71 user_name: Option<String>,
72 #[arg(long, help_heading = "Path parameters", value_name = "USER_ID")]
74 user_id: Option<String>,
75 #[arg(long, help_heading = "Path parameters", action = clap::ArgAction::SetTrue)]
77 current_user: bool,
78}
79
80#[derive(Args)]
82struct PathParameters {
83 #[arg(
85 help_heading = "Path parameters",
86 id = "path_param_id",
87 value_name = "ID"
88 )]
89 id: String,
90}
91
92impl QuotaSetCommand {
93 pub async fn take_action<C: CliArgs>(
95 &self,
96 parsed_args: &C,
97 client: &mut AsyncOpenStack,
98 ) -> Result<(), OpenStackCliError> {
99 info!("Delete QuotaSet");
100
101 let op = OutputProcessor::from_args(parsed_args, Some("compute.quota_set"), Some("delete"));
102 op.validate_args(parsed_args)?;
103
104 let mut ep_builder = delete::Request::builder();
105
106 ep_builder.id(&self.path.id);
107 if let Some(id) = &self.query.user.user_id {
109 ep_builder.user_id(id);
111 } else if let Some(name) = &self.query.user.user_name {
112 let mut sub_find_builder = find_user::Request::builder();
114 warn!(
115 "Querying user by name (because of `--user-name` parameter passed) may not be definite. This may fail in which case parameter `--user-id` should be used instead."
116 );
117
118 sub_find_builder.id(name);
119 let find_ep = sub_find_builder
120 .build()
121 .map_err(|x| OpenStackCliError::EndpointBuild(x.to_string()))?;
122 let find_data: serde_json::Value = find_by_name(find_ep).query_async(client).await?;
123 match find_data.get("id") {
125 Some(val) => match val.as_str() {
126 Some(id_str) => {
127 ep_builder.user_id(id_str.to_owned());
128 }
129 None => {
130 return Err(OpenStackCliError::ResourceAttributeNotString(
131 serde_json::to_string(&val)?,
132 ));
133 }
134 },
135 None => {
136 return Err(OpenStackCliError::ResourceAttributeMissing(
137 "id".to_string(),
138 ));
139 }
140 };
141 } else if self.query.user.current_user {
142 ep_builder.user_id(
143 client
144 .get_auth_info()
145 .ok_or_eyre("Cannot determine current authentication information")?
146 .token
147 .user
148 .id,
149 );
150 }
151
152 let ep = ep_builder
153 .build()
154 .map_err(|x| OpenStackCliError::EndpointBuild(x.to_string()))?;
155 openstack_sdk::api::ignore(ep).query_async(client).await?;
156 op.show_command_hint()?;
158 Ok(())
159 }
160}