openstack_cli_network/v2/ndp_proxy/
list.rs1use 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::network::v2::ndp_proxy::list;
32use openstack_sdk::api::{Pagination, paged};
33use openstack_types::network::v2::ndp_proxy::response;
34
35#[derive(Args)]
37pub struct NdpProxiesCommand {
38 #[command(flatten)]
40 query: QueryParameters,
41
42 #[command(flatten)]
44 path: PathParameters,
45
46 #[arg(long, default_value_t = 10000)]
48 max_items: usize,
49}
50
51#[derive(Args)]
53struct QueryParameters {
54 #[arg(help_heading = "Query parameters", long)]
56 description: Option<String>,
57
58 #[arg(
63 help_heading = "Query parameters",
64 long("page-size"),
65 visible_alias("limit")
66 )]
67 limit: Option<u32>,
68
69 #[arg(help_heading = "Query parameters", long)]
73 marker: Option<String>,
74
75 #[arg(help_heading = "Query parameters", long)]
77 name: Option<String>,
78
79 #[arg(action=clap::ArgAction::Set, help_heading = "Query parameters", long)]
81 page_reverse: Option<bool>,
82
83 #[arg(help_heading = "Query parameters", long)]
85 revision_number: Option<String>,
86
87 #[arg(action=clap::ArgAction::Append, help_heading = "Query parameters", long)]
90 sort_dir: Option<Vec<String>>,
91
92 #[arg(action=clap::ArgAction::Append, help_heading = "Query parameters", long)]
95 sort_key: Option<Vec<String>>,
96}
97
98#[derive(Args)]
100struct PathParameters {}
101
102impl NdpProxiesCommand {
103 pub async fn take_action<C: CliArgs>(
105 &self,
106 parsed_args: &C,
107 client: &mut AsyncOpenStack,
108 ) -> Result<(), OpenStackCliError> {
109 info!("List NdpProxies");
110
111 let op = OutputProcessor::from_args(parsed_args, Some("network.ndp_proxy"), Some("list"));
112 op.validate_args(parsed_args)?;
113
114 let mut ep_builder = list::Request::builder();
115
116 if let Some(val) = &self.query.limit {
118 ep_builder.limit(*val);
119 }
120 if let Some(val) = &self.query.marker {
121 ep_builder.marker(val);
122 }
123 if let Some(val) = &self.query.description {
124 ep_builder.description(val);
125 }
126 if let Some(val) = &self.query.name {
127 ep_builder.name(val);
128 }
129 if let Some(val) = &self.query.revision_number {
130 ep_builder.revision_number(val);
131 }
132 if let Some(val) = &self.query.page_reverse {
133 ep_builder.page_reverse(*val);
134 }
135 if let Some(val) = &self.query.sort_dir {
136 ep_builder.sort_dir(val.iter());
137 }
138 if let Some(val) = &self.query.sort_key {
139 ep_builder.sort_key(val.iter());
140 }
141
142 let ep = ep_builder
143 .build()
144 .map_err(|x| OpenStackCliError::EndpointBuild(x.to_string()))?;
145
146 let data: Vec<serde_json::Value> = paged(ep, Pagination::Limit(self.max_items))
147 .query_async(client)
148 .await?;
149
150 op.output_list::<response::list::NdpProxyResponse>(data.clone())?;
151 op.show_command_hint()?;
153 Ok(())
154 }
155}