diff options
Diffstat (limited to 'openstackclient/object/v1/object.py')
| -rw-r--r-- | openstackclient/object/v1/object.py | 118 |
1 files changed, 118 insertions, 0 deletions
diff --git a/openstackclient/object/v1/object.py b/openstackclient/object/v1/object.py new file mode 100644 index 00000000..c6bd755b --- /dev/null +++ b/openstackclient/object/v1/object.py @@ -0,0 +1,118 @@ +# Copyright 2013 Nebula Inc. +# +# 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. +# + +"""Object v1 action implementations""" + + +import logging + +from cliff import lister + +from openstackclient.common import utils +from openstackclient.object.v1.lib import object as lib_object + + +class ListObject(lister.Lister): + """List objects""" + + log = logging.getLogger(__name__ + '.ListObject') + + def get_parser(self, prog_name): + parser = super(ListObject, self).get_parser(prog_name) + parser.add_argument( + "container", + metavar="<container-name>", + help="List contents of container-name", + ) + parser.add_argument( + "--prefix", + metavar="<prefix>", + help="Filter list using <prefix>", + ) + parser.add_argument( + "--delimiter", + metavar="<delimiter>", + help="Roll up items with <delimiter>", + ) + parser.add_argument( + "--marker", + metavar="<marker>", + help="Anchor for paging", + ) + parser.add_argument( + "--end-marker", + metavar="<end-marker>", + help="End anchor for paging", + ) + parser.add_argument( + "--limit", + metavar="<limit>", + type=int, + help="Limit the number of objects returned", + ) + parser.add_argument( + '--long', + action='store_true', + default=False, + help='List additional fields in output', + ) + parser.add_argument( + '--all', + action='store_true', + default=False, + help='List all objects in container (default is 10000)', + ) + return parser + + def take_action(self, parsed_args): + self.log.debug('take_action(%s)' % parsed_args) + + if parsed_args.long: + columns = ( + 'Name', + 'Bytes', + 'Hash', + 'Content Type', + 'Last Modified', + ) + else: + columns = ('Name',) + + kwargs = {} + if parsed_args.prefix: + kwargs['prefix'] = parsed_args.prefix + if parsed_args.delimiter: + kwargs['delimiter'] = parsed_args.delimiter + if parsed_args.marker: + kwargs['marker'] = parsed_args.marker + if parsed_args.end_marker: + kwargs['end_marker'] = parsed_args.end_marker + if parsed_args.limit: + kwargs['limit'] = parsed_args.limit + if parsed_args.all: + kwargs['full_listing'] = True + + data = lib_object.list_objects( + self.app.restapi, + self.app.client_manager.object.endpoint, + parsed_args.container, + **kwargs + ) + + return (columns, + (utils.get_dict_properties( + s, columns, + formatters={}, + ) for s in data)) |
