# 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. # # Copyright 2015 IBM Corp. import logging from osc_lib.command import command from osc_lib import utils from heatclient._i18n import _ from heatclient.common import format_utils from heatclient.common import http from heatclient.common import template_utils from heatclient.common import utils as heat_utils from heatclient import exc class VersionList(command.Lister): """List the available template versions.""" log = logging.getLogger(__name__ + '.VersionList') def take_action(self, parsed_args): self.log.debug('take_action(%s)', parsed_args) client = self.app.client_manager.orchestration versions = client.template_versions.list() try: versions[1].aliases def format_alias(aliases): return ','.join(aliases) fields = ['Version', 'Type', 'Aliases'] formatters = {'Aliases': format_alias} except AttributeError: fields = ['Version', 'Type'] formatters = None items = (utils.get_item_properties(s, fields, formatters=formatters) for s in versions) return (fields, items) class FunctionList(command.Lister): """List the available functions.""" log = logging.getLogger(__name__ + '.FunctionList') def get_parser(self, prog_name): parser = super(FunctionList, self).get_parser(prog_name) parser.add_argument( 'template_version', metavar='', help=_('Template version to get the functions for') ) parser.add_argument( '--with_conditions', default=False, action='store_true', help=_('Show condition functions for template.') ) return parser def take_action(self, parsed_args): self.log.debug('take_action(%s)', parsed_args) client = self.app.client_manager.orchestration version = parsed_args.template_version try: functions = client.template_versions.get( version, with_condition_func=parsed_args.with_conditions) except exc.HTTPNotFound: msg = _('Template version not found: %s') % version raise exc.CommandError(msg) fields = ['Functions', 'Description'] return ( fields, (utils.get_item_properties(s, fields) for s in functions) ) class Validate(format_utils.YamlFormat): """Validate a template""" log = logging.getLogger(__name__ + ".Validate") def get_parser(self, prog_name): parser = super(Validate, self).get_parser(prog_name) parser.add_argument( '-e', '--environment', metavar='', action='append', help=_('Path to the environment. Can be specified multiple times') ) parser.add_argument( '--show-nested', action='store_true', help=_('Resolve parameters from nested templates as well') ) parser.add_argument( '--parameter', metavar='', action='append', help=_('Parameter values used to create the stack. This can be ' 'specified multiple times') ) parser.add_argument( '-s', '--files-container', metavar='', help=_('Swift files container name. Local files other than ' 'root template would be ignored. If other files are not ' 'found in swift, heat engine would raise an error.') ) parser.add_argument( '--ignore-errors', metavar='', help=_('List of heat errors to ignore') ) parser.add_argument( '-t', '--template', metavar='