Skip to main content

openstack_cli_network/v2/
default_security_group_rule.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//! DefaultSecurityGroupRule resource commands
16
17use clap::{Parser, Subcommand};
18
19use openstack_cli_core::{cli::CliArgs, error::OpenStackCliError};
20use openstack_sdk::AsyncOpenStack;
21
22pub mod create;
23pub mod delete;
24pub mod list;
25pub mod set;
26pub mod show;
27
28/// Security group default rules (security-group-default-rules)
29///
30/// Lists, creates, shows information for, and deletes security group default rules.
31#[derive(Parser)]
32pub struct DefaultSecurityGroupRuleCommand {
33    /// subcommand
34    #[command(subcommand)]
35    command: DefaultSecurityGroupRuleCommands,
36}
37
38/// Supported subcommands
39#[allow(missing_docs)]
40#[derive(Subcommand)]
41pub enum DefaultSecurityGroupRuleCommands {
42    Create(Box<create::DefaultSecurityGroupRuleCommand>),
43    Delete(Box<delete::DefaultSecurityGroupRuleCommand>),
44    List(Box<list::DefaultSecurityGroupRulesCommand>),
45    Set(Box<set::DefaultSecurityGroupRuleCommand>),
46    Show(Box<show::DefaultSecurityGroupRuleCommand>),
47}
48
49impl DefaultSecurityGroupRuleCommand {
50    /// Perform command action
51    pub async fn take_action<C: CliArgs>(
52        &self,
53        parsed_args: &C,
54        session: &mut AsyncOpenStack,
55    ) -> Result<(), OpenStackCliError> {
56        match &self.command {
57            DefaultSecurityGroupRuleCommands::Create(cmd) => {
58                cmd.take_action(parsed_args, session).await
59            }
60            DefaultSecurityGroupRuleCommands::Delete(cmd) => {
61                cmd.take_action(parsed_args, session).await
62            }
63            DefaultSecurityGroupRuleCommands::List(cmd) => {
64                cmd.take_action(parsed_args, session).await
65            }
66            DefaultSecurityGroupRuleCommands::Set(cmd) => {
67                cmd.take_action(parsed_args, session).await
68            }
69            DefaultSecurityGroupRuleCommands::Show(cmd) => {
70                cmd.take_action(parsed_args, session).await
71            }
72        }
73    }
74}