diff options
| author | Dean Troyer <dtroyer@gmail.com> | 2014-09-14 18:16:32 -0500 |
|---|---|---|
| committer | Dean Troyer <dtroyer@gmail.com> | 2014-09-18 15:42:10 -0500 |
| commit | da45b34828bbc4000b1ede68f10bbcc1e4a47cc1 (patch) | |
| tree | a4c25595d3c9b8eedebdb90f55430a4d81ee806c /openstackclient/identity | |
| parent | ae957b176e5918f41024c00cbc39ea371a0c37c6 (diff) | |
| download | python-openstackclient-da45b34828bbc4000b1ede68f10bbcc1e4a47cc1.tar.gz | |
Add service catalog commands
'catalog list' and 'catalog show' for Identity v2
Identity v2 only so far.
Change-Id: I9df0dac3d5bb7c18f38a81bd7d29f8119462d3a5
Diffstat (limited to 'openstackclient/identity')
| -rw-r--r-- | openstackclient/identity/v2_0/catalog.py | 98 |
1 files changed, 98 insertions, 0 deletions
diff --git a/openstackclient/identity/v2_0/catalog.py b/openstackclient/identity/v2_0/catalog.py new file mode 100644 index 00000000..7bda1acb --- /dev/null +++ b/openstackclient/identity/v2_0/catalog.py @@ -0,0 +1,98 @@ +# 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. +# + +"""Identity v2 Service Catalog action implementations""" + +import logging +import six + +from cliff import lister +from cliff import show + +from openstackclient.common import utils + + +def _format_endpoints(eps=None): + if not eps: + return "" + for index, ep in enumerate(eps): + ret = eps[index]['region'] + '\n' + for url in ['publicURL', 'internalURL', 'adminURL']: + ret += " %s: %s\n" % (url, eps[index]['publicURL']) + return ret + + +class ListCatalog(lister.Lister): + """List services in the service catalog""" + + log = logging.getLogger(__name__ + '.ListCatalog') + + def take_action(self, parsed_args): + self.log.debug('take_action(%s)', parsed_args) + + # This is ugly because if auth hasn't happened yet we need + # to trigger it here. + sc = self.app.client_manager.session.auth.get_auth_ref( + self.app.client_manager.session, + ).service_catalog + + data = sc.get_data() + columns = ('Name', 'Type', 'Endpoints') + return (columns, + (utils.get_dict_properties( + s, columns, + formatters={ + 'Endpoints': _format_endpoints, + }, + ) for s in data)) + + +class ShowCatalog(show.ShowOne): + """Show service catalog details""" + + log = logging.getLogger(__name__ + '.ShowCatalog') + + def get_parser(self, prog_name): + parser = super(ShowCatalog, self).get_parser(prog_name) + parser.add_argument( + 'service', + metavar='<service>', + help='Service to display (type, name or ID)', + ) + return parser + + def take_action(self, parsed_args): + self.log.debug('take_action(%s)', parsed_args) + + # This is ugly because if auth hasn't happened yet we need + # to trigger it here. + sc = self.app.client_manager.session.auth.get_auth_ref( + self.app.client_manager.session, + ).service_catalog + + data = None + for service in sc.get_data(): + if ( + 'name' in service and + service['name'] != parsed_args.service and + 'type' in service and + service['type'] != parsed_args.service + ): + continue + + data = service + data['endpoints'] = _format_endpoints(data['endpoints']) + if 'endpoints_links' in data: + data.pop('endpoints_links') + + return zip(*sorted(six.iteritems(data))) |
