Skip to main content

openstack_cli_load_balancer/v2/amphorae/
show.rs

1// Licensed under the Apache License, Version 2.0 (the "License");
2// you may not use this file except in compliance with the License.
3// You may obtain a copy of the License at
4//
5//     http://www.apache.org/licenses/LICENSE-2.0
6//
7// Unless required by applicable law or agreed to in writing, software
8// distributed under the License is distributed on an "AS IS" BASIS,
9// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
10// See the License for the specific language governing permissions and
11// limitations under the License.
12//
13// SPDX-License-Identifier: Apache-2.0
14//
15// WARNING: This file is automatically generated from OpenAPI schema using
16// `openstack-codegenerator`.
17
18//! Show Amphorae command
19//!
20//! Wraps invoking of the `v2/octavia/amphorae/{amphora_id}` with `GET` method
21
22use clap::Args;
23use tracing::info;
24
25use openstack_cli_core::cli::CliArgs;
26use openstack_cli_core::error::OpenStackCliError;
27use openstack_cli_core::output::OutputProcessor;
28use openstack_sdk::AsyncOpenStack;
29
30use openstack_sdk::api::QueryAsync;
31use openstack_sdk::api::load_balancer::v2::amphorae::get;
32use openstack_types::load_balancer::v2::amphorae::response;
33
34/// Shows the details of an amphora.
35///
36/// If you are not an administrative user, the service returns the HTTP
37/// `Forbidden (403)` response code.
38///
39/// This operation does not require a request body.
40#[derive(Args)]
41#[command(about = "Show Amphora details")]
42pub struct AmphoraeCommand {
43    /// Request Query parameters
44    #[command(flatten)]
45    query: QueryParameters,
46
47    /// Path parameters
48    #[command(flatten)]
49    path: PathParameters,
50}
51
52/// Query parameters
53#[derive(Args)]
54struct QueryParameters {}
55
56/// Path parameters
57#[derive(Args)]
58struct PathParameters {
59    /// amphora_id parameter for /v2/octavia/amphorae/{amphora_id} API
60    #[arg(
61        help_heading = "Path parameters",
62        id = "path_param_amphora_id",
63        value_name = "AMPHORA_ID"
64    )]
65    amphora_id: String,
66}
67
68impl AmphoraeCommand {
69    /// Perform command action
70    pub async fn take_action<C: CliArgs>(
71        &self,
72        parsed_args: &C,
73        client: &mut AsyncOpenStack,
74    ) -> Result<(), OpenStackCliError> {
75        info!("Show Amphorae");
76
77        let op =
78            OutputProcessor::from_args(parsed_args, Some("load-balancer.amphorae"), Some("show"));
79        op.validate_args(parsed_args)?;
80
81        let mut ep_builder = get::Request::builder();
82
83        ep_builder.amphora_id(&self.path.amphora_id);
84
85        let ep = ep_builder
86            .build()
87            .map_err(|x| OpenStackCliError::EndpointBuild(x.to_string()))?;
88
89        let data: serde_json::Value = ep.query_async(client).await?;
90
91        op.output_single::<response::get::AmphoraeResponse>(data.clone())?;
92        // Show command specific hints
93        op.show_command_hint()?;
94        Ok(())
95    }
96}