openstack_cli_compute/v2/server/diagnostic/get.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//! Get Diagnostic command
19//!
20//! Wraps invoking of the `v2.1/servers/{server_id}/diagnostics` 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::compute::v2::server::diagnostic::get;
32use openstack_types::compute::v2::server::diagnostic::response;
33
34/// Shows basic usage data for a server.
35///
36/// Policy defaults enable only users with the administrative role. Cloud
37/// providers can change these permissions through the `policy.yaml` file.
38///
39/// Normal response codes: 200
40///
41/// Error response codes: unauthorized(401), forbidden(403), notfound(404),
42/// conflict(409), notimplemented(501)
43#[derive(Args)]
44#[command(about = "Show Server Diagnostics")]
45pub struct DiagnosticCommand {
46 /// Request Query parameters
47 #[command(flatten)]
48 query: QueryParameters,
49
50 /// Path parameters
51 #[command(flatten)]
52 path: PathParameters,
53}
54
55/// Query parameters
56#[derive(Args)]
57struct QueryParameters {}
58
59/// Path parameters
60#[derive(Args)]
61struct PathParameters {
62 /// server_id parameter for /v2.1/servers/{server_id}/diagnostics API
63 #[arg(
64 help_heading = "Path parameters",
65 id = "path_param_server_id",
66 value_name = "SERVER_ID"
67 )]
68 server_id: String,
69}
70
71impl DiagnosticCommand {
72 /// Perform command action
73 pub async fn take_action<C: CliArgs>(
74 &self,
75 parsed_args: &C,
76 client: &mut AsyncOpenStack,
77 ) -> Result<(), OpenStackCliError> {
78 info!("Get Diagnostic");
79
80 let op =
81 OutputProcessor::from_args(parsed_args, Some("compute.server/diagnostic"), Some("get"));
82 op.validate_args(parsed_args)?;
83
84 let mut ep_builder = get::Request::builder();
85
86 ep_builder.server_id(&self.path.server_id);
87
88 let ep = ep_builder
89 .build()
90 .map_err(|x| OpenStackCliError::EndpointBuild(x.to_string()))?;
91
92 let data: serde_json::Value = ep.query_async(client).await?;
93
94 op.output_single::<response::get_21::DiagnosticResponse>(data.clone())
95 .or_else(|_| op.output_single::<response::get_248::DiagnosticResponse>(data.clone()))?;
96 // Show command specific hints
97 op.show_command_hint()?;
98 Ok(())
99 }
100}