summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJenkins <jenkins@review.openstack.org>2013-03-01 18:08:46 +0000
committerGerrit Code Review <review@openstack.org>2013-03-01 18:08:46 +0000
commit287c23ca4b023a53898e839dc2247d83b437c7f8 (patch)
treefcee05a81de5bb8a1a00006f1fc88e9e8cb967d1
parent87375392a8fd4e6583734be5e5a31801ffa4016d (diff)
parentf67daad71667c85e4cb5621b8755dbed39b23304 (diff)
downloadpython-openstackclient-287c23ca4b023a53898e839dc2247d83b437c7f8.tar.gz
Merge "Added compute flavor support."
-rw-r--r--openstackclient/compute/v2/flavor.py186
-rw-r--r--setup.py4
2 files changed, 190 insertions, 0 deletions
diff --git a/openstackclient/compute/v2/flavor.py b/openstackclient/compute/v2/flavor.py
new file mode 100644
index 00000000..40418132
--- /dev/null
+++ b/openstackclient/compute/v2/flavor.py
@@ -0,0 +1,186 @@
+# Copyright 2013 OpenStack, LLC.
+#
+# Licensed under the Apache License, Version 2.0 (the "License"); you may
+# not use this file except in compliance with the License. You may obtain
+# a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+# License for the specific language governing permissions and limitations
+# under the License.
+#
+
+"""Flavor action implementations"""
+
+import logging
+
+from cliff import command
+from cliff import lister
+from cliff import show
+
+from novaclient.v1_1 import flavors
+from openstackclient.common import utils
+
+
+class CreateFlavor(show.ShowOne):
+ """Create flavor command"""
+
+ api = "compute"
+ log = logging.getLogger(__name__ + ".CreateFlavor")
+
+ def get_parser(self, prog_name):
+ parser = super(CreateFlavor, self).get_parser(prog_name)
+ parser.add_argument(
+ "name",
+ metavar="<name>",
+ help="Name of the new flavor")
+ parser.add_argument(
+ "id",
+ metavar="<id>",
+ help="Unique ID (integer or UUID) for the new flavor."
+ " If specifying 'auto', a UUID will be generated as id")
+ parser.add_argument(
+ "ram",
+ type=int,
+ metavar="<ram>",
+ help="Memory size in MB")
+ parser.add_argument(
+ "disk",
+ type=int,
+ metavar="<disk>",
+ help="Disk size in GB")
+ parser.add_argument(
+ "--ephemeral",
+ type=int,
+ metavar="<ephemeral>",
+ help="Ephemeral space size in GB (default 0)",
+ default=0)
+ parser.add_argument(
+ "vcpus",
+ type=int,
+ metavar="<vcpus>",
+ help="Number of vcpus")
+ parser.add_argument(
+ "--swap",
+ type=int,
+ metavar="<swap>",
+ help="Swap space size in MB (default 0)",
+ default=0)
+ parser.add_argument(
+ "--rxtx-factor",
+ type=int,
+ metavar="<factor>",
+ help="RX/TX factor (default 1)",
+ default=1)
+ public_group = parser.add_mutually_exclusive_group()
+ public_group.add_argument(
+ "--public",
+ dest="public",
+ default=True,
+ help="Make flavor inaccessible to the public (default)",
+ action="store_true")
+ public_group.add_argument(
+ "--private",
+ dest="public",
+ help="Make flavor inaccessible to the public",
+ action="store_false")
+ return parser
+
+ def take_action(self, parsed_args):
+ self.log.debug("take_action(%s)" % parsed_args)
+ compute_client = self.app.client_manager.compute
+
+ args = (
+ parsed_args.name,
+ parsed_args.ram,
+ parsed_args.vcpus,
+ parsed_args.disk,
+ parsed_args.id,
+ parsed_args.ephemeral,
+ parsed_args.swap,
+ parsed_args.rxtx_factor,
+ parsed_args.public
+ )
+
+ flavor = compute_client.flavors.create(*args)._info.copy()
+ flavor.pop("links")
+
+ return zip(*sorted(flavor.iteritems()))
+
+
+class DeleteFlavor(command.Command):
+ """Delete flavor command"""
+
+ api = "compute"
+ log = logging.getLogger(__name__ + ".DeleteFlavor")
+
+ def get_parser(self, prog_name):
+ parser = super(DeleteFlavor, self).get_parser(prog_name)
+ parser.add_argument(
+ "flavor",
+ metavar="<flavor>",
+ help="Name or ID of flavor to delete")
+ return parser
+
+ def take_action(self, parsed_args):
+ self.log.debug("take_action(%s)" % parsed_args)
+ compute_client = self.app.client_manager.compute
+ flavor = utils.find_resource(compute_client.flavors,
+ parsed_args.flavor)
+ compute_client.flavors.delete(flavor.id)
+ return
+
+
+class ListFlavor(lister.Lister):
+ """List flavor command"""
+
+ api = "compute"
+ log = logging.getLogger(__name__ + ".ListFlavor")
+
+ def take_action(self, parsed_args):
+ self.log.debug("take_action(%s)" % parsed_args)
+ compute_client = self.app.client_manager.compute
+ columns = (
+ "ID",
+ "Name",
+ "RAM",
+ "Disk",
+ "Ephemeral",
+ "Swap",
+ "VCPUs",
+ "RXTX Factor",
+ "Is Public",
+ "Extra Specs"
+ )
+ data = compute_client.flavors.list()
+ return (columns,
+ (utils.get_item_properties(
+ s, columns,
+ ) for s in data))
+
+
+class ShowFlavor(show.ShowOne):
+ """Show flavor command"""
+
+ api = "compute"
+ log = logging.getLogger(__name__ + ".ShowFlavor")
+
+ def get_parser(self, prog_name):
+ parser = super(ShowFlavor, self).get_parser(prog_name)
+ parser.add_argument(
+ "flavor",
+ metavar="<flavor>",
+ help="Name or ID of flavor to display")
+ return parser
+
+ def take_action(self, parsed_args):
+ self.log.debug("take_action(%s)" % parsed_args)
+ compute_client = self.app.client_manager.compute
+ flavor = utils.find_resource(compute_client.flavors,
+ parsed_args.flavor)._info.copy()
+ flavor.pop("links")
+
+ return zip(*sorted(flavor.iteritems()))
diff --git a/setup.py b/setup.py
index 2e1b914f..3ad427f5 100644
--- a/setup.py
+++ b/setup.py
@@ -125,16 +125,20 @@ setuptools.setup(
],
'openstack.compute.v2': [
'create_agent=openstackclient.compute.v2.agent:CreateAgent',
+ 'create_flavor=openstackclient.compute.v2.flavor:CreateFlavor',
'create_server=openstackclient.compute.v2.server:CreateServer',
'delete_agent=openstackclient.compute.v2.agent:DeleteAgent',
+ 'delete_flavor=openstackclient.compute.v2.flavor:DeleteFlavor',
'delete_server=openstackclient.compute.v2.server:DeleteServer',
'list_agent=openstackclient.compute.v2.agent:ListAgent',
+ 'list_flavor=openstackclient.compute.v2.flavor:ListFlavor',
'list_server=openstackclient.compute.v2.server:ListServer',
'pause_server=openstackclient.compute.v2.server:PauseServer',
'reboot_server=openstackclient.compute.v2.server:RebootServer',
'rebuild_server=openstackclient.compute.v2.server:RebuildServer',
'resume_server=openstackclient.compute.v2.server:ResumeServer',
'set_agent=openstackclient.compute.v2.agent:SetAgent',
+ 'show_flavor=openstackclient.compute.v2.flavor:ShowFlavor',
'show_server=openstackclient.compute.v2.server:ShowServer',
'suspend_server=openstackclient.compute.v2.server:SuspendServer',
'unpause_server=openstackclient.compute.v2.server:UnpauseServer',