heat-translator/translator/hot/tosca_translator.py
srinivas_tadepalli 924cfb0ac8 Supporting logging in heat-translator with config file
Added heat-translator-logging.conf
heat-translator.py and osc/v1/translate.py reads configuration file.
Added warning log messages before raising exceptions
To be added proper log messages in the code with other log levels

Partially Implements: blueprint heat-translator-logging

Change-Id: I5aeb39a83dc8dcc59245968d3dd8a6451d93865c
2015-09-04 12:46:58 +05:30

65 lines
2.6 KiB
Python

#
# 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.
import logging
from translator.hot.syntax.hot_template import HotTemplate
from translator.hot.translate_inputs import TranslateInputs
from translator.hot.translate_node_templates import TranslateNodeTemplates
from translator.hot.translate_outputs import TranslateOutputs
class TOSCATranslator(object):
'''Invokes translation methods.'''
log = logging.getLogger('heat-translator')
def __init__(self, tosca, parsed_params):
super(TOSCATranslator, self).__init__()
self.tosca = tosca
self.hot_template = HotTemplate()
self.parsed_params = parsed_params
self.node_translator = None
def translate(self):
self._resolve_input()
self.hot_template.description = self.tosca.description
self.hot_template.parameters = self._translate_inputs()
self.node_translator = TranslateNodeTemplates(self.tosca,
self.hot_template)
self.hot_template.resources = self.node_translator.translate()
self.hot_template.outputs = self._translate_outputs()
return self.hot_template.output_to_yaml()
def _translate_inputs(self):
translator = TranslateInputs(self.tosca.inputs, self.parsed_params)
return translator.translate()
def _translate_outputs(self):
translator = TranslateOutputs(self.tosca.outputs, self.node_translator)
return translator.translate()
# check all properties for all node and ensure they are resolved
# to actual value
def _resolve_input(self):
for n in self.tosca.nodetemplates:
for node_prop in n.get_properties_objects():
if isinstance(node_prop.value, dict):
try:
self.parsed_params[node_prop.value['get_input']]
except Exception:
msg = (_('Must specify all input values in \
TOSCA template, missing %s') %
node_prop.value['get_input'])
self.log.warning(msg)
raise ValueError(msg)