Skip to main content

openstack_cli_block_storage/v3/
volume_manage.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//! Block storage Manageable Volume commands
16//!
17
18use clap::{Parser, Subcommand};
19
20use openstack_cli_core::{cli::CliArgs, error::OpenStackCliError};
21use openstack_sdk::AsyncOpenStack;
22
23pub mod create_30;
24pub mod create_316;
25pub mod list;
26
27/// Volume manage extension (manageable_volumes)
28///
29/// Creates or lists volumes by using existing storage instead of allocating new storage.
30#[derive(Parser)]
31pub struct VolumeManageCommand {
32    /// subcommand
33    #[command(subcommand)]
34    command: VolumeManageCommands,
35}
36
37/// Supported subcommands
38#[allow(missing_docs)]
39#[derive(Subcommand)]
40pub enum VolumeManageCommands {
41    #[command(visible_alias = "create")]
42    Create316(Box<create_316::VolumeManageCommand>),
43    Create30(Box<create_30::VolumeManageCommand>),
44    List(Box<list::VolumeManagesCommand>),
45}
46
47impl VolumeManageCommand {
48    /// Perform command action
49    pub async fn take_action<C: CliArgs>(
50        &self,
51        parsed_args: &C,
52        session: &mut AsyncOpenStack,
53    ) -> Result<(), OpenStackCliError> {
54        match &self.command {
55            VolumeManageCommands::Create316(cmd) => cmd.take_action(parsed_args, session).await,
56            VolumeManageCommands::Create30(cmd) => cmd.take_action(parsed_args, session).await,
57            VolumeManageCommands::List(cmd) => cmd.take_action(parsed_args, session).await,
58        }
59    }
60}