Skip to main content

openstack_cli_network/
v2.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//! Networking v2 commands
16
17use clap::{Parser, Subcommand};
18
19use openstack_cli_core::{cli::CliArgs, error::OpenStackCliError};
20use openstack_sdk::{AsyncOpenStack, types::ServiceType};
21
22pub mod address_group;
23pub mod address_scope;
24pub mod agent;
25pub mod auto_allocated_topology;
26pub mod availability_zone;
27pub mod default_security_group_rule;
28pub mod extension;
29pub mod flavor;
30pub mod floatingip;
31pub mod floatingip_pool;
32pub mod local_ip;
33pub mod log;
34pub mod metering;
35pub mod ndp_proxy;
36pub mod network;
37pub mod network_ip_availability;
38pub mod network_segment_range;
39pub mod port;
40pub mod qos;
41pub mod quota;
42pub mod rbac_policy;
43pub mod router;
44pub mod security_group;
45pub mod security_group_rule;
46pub mod segment;
47pub mod subnet;
48pub mod subnetpool;
49pub mod vpn;
50
51/// Network (Neutron) commands
52#[derive(Parser)]
53pub struct NetworkCommand {
54    /// Network service resource
55    #[command(subcommand)]
56    command: NetworkCommands,
57}
58
59/// Supported subcommands
60#[allow(missing_docs)]
61#[derive(Subcommand)]
62pub enum NetworkCommands {
63    AddressGroup(Box<address_group::AddressGroupCommand>),
64    AddressScope(Box<address_scope::AddressScopeCommand>),
65    Agent(Box<agent::AgentCommand>),
66    AutoAllocatedTopology(Box<auto_allocated_topology::AutoAllocatedTopologyCommand>),
67    AvailabilityZone(Box<availability_zone::AvailabilityZoneCommand>),
68    DefaultSecurityGroupRule(Box<default_security_group_rule::DefaultSecurityGroupRuleCommand>),
69    Extension(Box<extension::ExtensionCommand>),
70    Flavor(Box<flavor::FlavorCommand>),
71    FloatingIP(Box<floatingip::FloatingIPCommand>),
72    FloatingIPPool(Box<floatingip_pool::FloatingIPPoolCommand>),
73    LocalIP(Box<local_ip::LocalIPCommand>),
74    Log(Box<log::LogCommand>),
75    Metering(Box<metering::MeteringCommand>),
76    NdpProxy(Box<ndp_proxy::NdpProxyCommand>),
77    Network(Box<network::NetworkCommand>),
78    NetworkIpAvailability(Box<network_ip_availability::NetworkIpAvailabilityCommand>),
79    NetworkSegmentRange(Box<network_segment_range::NetworkSegmentRangeCommand>),
80    Port(Box<port::PortCommand>),
81    Qos(Box<qos::QosCommand>),
82    Quota(Box<quota::QuotaCommand>),
83    RbacPolicy(Box<rbac_policy::RbacPolicyCommand>),
84    Router(Box<router::RouterCommand>),
85    SecurityGroup(Box<security_group::SecurityGroupCommand>),
86    SecurityGroupRule(Box<security_group_rule::SecurityGroupRuleCommand>),
87    Segment(Box<segment::SegmentCommand>),
88    Subnet(Box<subnet::SubnetCommand>),
89    #[command(visible_alias = "subnet-pool")]
90    Subnetpool(Box<subnetpool::SubnetPoolCommand>),
91    Vpn(Box<vpn::VpnCommand>),
92}
93
94impl NetworkCommand {
95    /// Perform command action
96    pub async fn take_action<C: CliArgs>(
97        &self,
98        parsed_args: &C,
99        session: &mut AsyncOpenStack,
100    ) -> Result<(), OpenStackCliError> {
101        session
102            .discover_service_endpoint(&ServiceType::Network)
103            .await?;
104
105        match &self.command {
106            NetworkCommands::AddressGroup(cmd) => cmd.take_action(parsed_args, session).await,
107            NetworkCommands::AddressScope(cmd) => cmd.take_action(parsed_args, session).await,
108            NetworkCommands::Agent(cmd) => cmd.take_action(parsed_args, session).await,
109            NetworkCommands::AutoAllocatedTopology(cmd) => {
110                cmd.take_action(parsed_args, session).await
111            }
112            NetworkCommands::AvailabilityZone(cmd) => cmd.take_action(parsed_args, session).await,
113            NetworkCommands::DefaultSecurityGroupRule(cmd) => {
114                cmd.take_action(parsed_args, session).await
115            }
116            NetworkCommands::Extension(cmd) => cmd.take_action(parsed_args, session).await,
117            NetworkCommands::Flavor(cmd) => cmd.take_action(parsed_args, session).await,
118            NetworkCommands::FloatingIP(cmd) => cmd.take_action(parsed_args, session).await,
119            NetworkCommands::FloatingIPPool(cmd) => cmd.take_action(parsed_args, session).await,
120            NetworkCommands::LocalIP(cmd) => cmd.take_action(parsed_args, session).await,
121            NetworkCommands::Log(cmd) => cmd.take_action(parsed_args, session).await,
122            NetworkCommands::Metering(cmd) => cmd.take_action(parsed_args, session).await,
123            NetworkCommands::NdpProxy(cmd) => cmd.take_action(parsed_args, session).await,
124            NetworkCommands::Network(cmd) => cmd.take_action(parsed_args, session).await,
125            NetworkCommands::NetworkIpAvailability(cmd) => {
126                cmd.take_action(parsed_args, session).await
127            }
128            NetworkCommands::NetworkSegmentRange(cmd) => {
129                cmd.take_action(parsed_args, session).await
130            }
131            NetworkCommands::Port(cmd) => cmd.take_action(parsed_args, session).await,
132            NetworkCommands::Qos(cmd) => cmd.take_action(parsed_args, session).await,
133            NetworkCommands::Quota(cmd) => cmd.take_action(parsed_args, session).await,
134            NetworkCommands::RbacPolicy(cmd) => cmd.take_action(parsed_args, session).await,
135            NetworkCommands::Router(cmd) => cmd.take_action(parsed_args, session).await,
136            NetworkCommands::SecurityGroup(cmd) => cmd.take_action(parsed_args, session).await,
137            NetworkCommands::SecurityGroupRule(cmd) => cmd.take_action(parsed_args, session).await,
138            NetworkCommands::Segment(cmd) => cmd.take_action(parsed_args, session).await,
139            NetworkCommands::Subnet(cmd) => cmd.take_action(parsed_args, session).await,
140            NetworkCommands::Subnetpool(cmd) => cmd.take_action(parsed_args, session).await,
141            NetworkCommands::Vpn(cmd) => cmd.take_action(parsed_args, session).await,
142        }
143    }
144}