summaryrefslogtreecommitdiff
path: root/openstackclient/identity
diff options
context:
space:
mode:
authorDean Troyer <dtroyer@gmail.com>2014-09-14 18:16:32 -0500
committerDean Troyer <dtroyer@gmail.com>2014-09-18 15:42:10 -0500
commitda45b34828bbc4000b1ede68f10bbcc1e4a47cc1 (patch)
treea4c25595d3c9b8eedebdb90f55430a4d81ee806c /openstackclient/identity
parentae957b176e5918f41024c00cbc39ea371a0c37c6 (diff)
downloadpython-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.py98
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)))