# 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. """Hosts resource and resource shell wrapper.""" from __future__ import print_function from cratonclient.common import cliutils from cratonclient import exceptions as exc from cratonclient.v1 import regions @cliutils.arg('-n', '--name', metavar='', required=True, help='Name of the host.') @cliutils.arg('--cloud', dest='cloud_id', metavar='', type=int, required=True, help='ID of the cloud that the region belongs to.') @cliutils.arg('--note', help='Note about the host.') def do_region_create(cc, args): """Register a new region with the Craton service.""" fields = {k: v for (k, v) in vars(args).items() if k in regions.REGION_FIELDS and not (v is None)} region = cc.regions.create(**fields) data = {f: getattr(region, f, '') for f in regions.REGION_FIELDS} cliutils.print_dict(data, wrap=72) @cliutils.arg('--cloud', metavar='', type=int, help='ID of the cloud that the region belongs to.') @cliutils.arg('--fields', nargs='+', metavar='', default=[], help='Comma-separated list of fields to display. ' 'Only these fields will be fetched from the server. ' 'Can not be used when "--detail" is specified') @cliutils.arg('--all', action='store_true', default=False, help='Retrieve and show all regions. This will override ' 'the provided value for --limit and automatically ' 'retrieve each page of results.') @cliutils.arg('--limit', metavar='', type=int, help='Maximum number of regions to return.') @cliutils.arg('--marker', metavar='', default=None, help='ID of the region to use to resume listing regions.') def do_region_list(cc, args): """List all regions.""" params = {} default_fields = ['id', 'name'] if args.cloud is not None: params['cloud_id'] = args.cloud if args.limit is not None: if args.limit < 0: raise exc.CommandError('Invalid limit specified. Expected ' 'non-negative limit, got {0}' .format(args.limit)) params['limit'] = args.limit if args.all is True: params['limit'] = 100 if args.fields: try: fields = {x: regions.REGION_FIELDS[x] for x in args.fields} except KeyError as err: raise exc.CommandError('Invalid field "{}"'.format(err.args[0])) else: fields = default_fields params['marker'] = args.marker params['autopaginate'] = args.all regions_list = cc.regions.list(**params) cliutils.print_list(regions_list, list(fields)) @cliutils.arg('id', metavar='', type=int, help='ID of the region.') def do_region_show(cc, args): """Show detailed information about a region.""" region = cc.regions.get(args.id) data = {f: getattr(region, f, '') for f in regions.REGION_FIELDS} cliutils.print_dict(data, wrap=72) @cliutils.arg('id', metavar='', type=int, help='ID of the region') @cliutils.arg('-n', '--name', metavar='', help='Name of the region.') @cliutils.arg('--cloud', dest='cloud_id', metavar='', type=int, help='Desired ID of the cloud that the region should change to.') @cliutils.arg('--note', help='Note about the region.') def do_region_update(cc, args): """Update a region that is registered with the Craton service.""" fields = {k: v for (k, v) in vars(args).items() if k in regions.REGION_FIELDS and not (v is None)} item_id = fields.pop('id') if not fields: raise exc.CommandError( 'Nothing to update... Please specify one or more of --name, ' '--cloud, or --note' ) region = cc.regions.update(item_id, **fields) data = {f: getattr(region, f, '') for f in regions.REGION_FIELDS} cliutils.print_dict(data, wrap=72) @cliutils.arg('id', metavar='', type=int, help='ID of the region.') def do_region_delete(cc, args): """Delete a region that is registered with the Craton service.""" try: response = cc.regions.delete(args.id) except exc.ClientException as client_exc: raise exc.CommandError( 'Failed to delete region {} due to "{}:{}"'.format( args.id, client_exc.__class__, str(client_exc), ) ) else: print("Region {0} was {1} deleted.". format(args.id, 'successfully' if response else 'not'))