1use 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#[derive(Parser)]
53pub struct NetworkCommand {
54 #[command(subcommand)]
56 command: NetworkCommands,
57}
58
59#[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 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}