diff options
| author | Jenkins <jenkins@review.openstack.org> | 2013-07-26 19:55:52 +0000 |
|---|---|---|
| committer | Gerrit Code Review <review@openstack.org> | 2013-07-26 19:55:52 +0000 |
| commit | 22386eb9e621012429e0626044c12b764d2ea273 (patch) | |
| tree | 8aed5cae1ad1ce74de64ed79e09445c1fa371d2e /openstackclient | |
| parent | ec9b907e780a16a5e4f8b6997b15473e44a93183 (diff) | |
| parent | fcc34652ecad4029998e45c32016af1b03256fc5 (diff) | |
| download | python-openstackclient-22386eb9e621012429e0626044c12b764d2ea273.tar.gz | |
Merge "Add usage command for compute api"
Diffstat (limited to 'openstackclient')
| -rw-r--r-- | openstackclient/compute/v2/usage.py | 91 |
1 files changed, 91 insertions, 0 deletions
diff --git a/openstackclient/compute/v2/usage.py b/openstackclient/compute/v2/usage.py new file mode 100644 index 00000000..0bfbc9b8 --- /dev/null +++ b/openstackclient/compute/v2/usage.py @@ -0,0 +1,91 @@ +# Copyright 2013 OpenStack Foundation. +# +# 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. +# + +"""Usage action implementations""" + +import datetime +import logging + +from cliff import lister + +from openstackclient.common import utils + + +class ListUsage(lister.Lister): + """List resource usage per project. """ + + log = logging.getLogger(__name__ + ".ListUsage") + + def get_parser(self, prog_name): + parser = super(ListUsage, self).get_parser(prog_name) + parser.add_argument( + "--start", + metavar="<start>", + default=None, + help="Usage range start date ex 2012-01-20" + " (default: 4 weeks ago)." + ) + parser.add_argument( + "--end", + metavar="<end>", + default=None, + help="Usage range end date, ex 2012-01-20 (default: tomorrow)" + ) + return parser + + def take_action(self, parsed_args): + self.log.debug("take_action(%s)" % parsed_args) + compute_client = self.app.client_manager.compute + columns = ( + "tenant_id", + "total_memory_mb_usage", + "total_vcpus_usage", + "total_local_gb_usage" + ) + column_headers = ( + "Project ID", + "RAM MB-Hours", + "CPU Hours", + "Disk GB-Hours" + ) + + dateformat = "%Y-%m-%d" + now = datetime.datetime.utcnow() + + if parsed_args.start: + start = datetime.datetime.strptime(parsed_args.start, dateformat) + else: + start = now - datetime.timedelta(weeks=4) + + if parsed_args.end: + end = datetime.datetime.strptime(parsed_args.end, dateformat) + else: + end = now + datetime.timedelta(days=1) + + usage_list = compute_client.usage.list(start, end) + + if len(usage_list) > 0: + print("Usage from %s to %s:" % (start.strftime(dateformat), + end.strftime(dateformat))) + + return (column_headers, + (utils.get_item_properties( + s, columns, + formatters={ + 'total_memory_mb_usage': lambda x: float("%.2f" % x), + 'total_vcpus_usage': lambda x: float("%.2f" % x), + 'total_local_gb_usage': lambda x: float("%.2f" % x), + }, + ) for s in usage_list)) |
