Re-enable lazy translation

After enhancements to Oslo Message class, re-enable lazy translation to
enable REST API responses to be translated to the requested user locale.
bp i18n-messages
Change-Id: I4be508858547029d454412746609fd380af415c1
This commit is contained in:
Ethan Lynn 2014-05-04 17:02:58 +08:00
parent 3407a698bd
commit f864a0c84a
6 changed files with 16 additions and 6 deletions

View File

@ -38,7 +38,8 @@ from heat.common import wsgi
from heat.openstack.common import gettextutils from heat.openstack.common import gettextutils
from heat.openstack.common import log as logging from heat.openstack.common import log as logging
gettextutils.install('heat', lazy=False) gettextutils.enable_lazy()
gettextutils.install('heat', lazy=True)
LOG = logging.getLogger('heat.api') LOG = logging.getLogger('heat.api')

View File

@ -40,7 +40,8 @@ from heat.common import wsgi
from heat.openstack.common import gettextutils from heat.openstack.common import gettextutils
from heat.openstack.common import log as logging from heat.openstack.common import log as logging
gettextutils.install('heat', lazy=False) gettextutils.enable_lazy()
gettextutils.install('heat', lazy=True)
LOG = logging.getLogger('heat.api.cfn') LOG = logging.getLogger('heat.api.cfn')

View File

@ -40,7 +40,8 @@ from heat.common import wsgi
from heat.openstack.common import gettextutils from heat.openstack.common import gettextutils
from heat.openstack.common import log as logging from heat.openstack.common import log as logging
gettextutils.install('heat', lazy=False) gettextutils.enable_lazy()
gettextutils.install('heat', lazy=True)
LOG = logging.getLogger('heat.api.cloudwatch') LOG = logging.getLogger('heat.api.cloudwatch')

View File

@ -32,7 +32,6 @@ POSSIBLE_TOPDIR = os.path.normpath(os.path.join(os.path.abspath(sys.argv[0]),
if os.path.exists(os.path.join(POSSIBLE_TOPDIR, 'heat', '__init__.py')): if os.path.exists(os.path.join(POSSIBLE_TOPDIR, 'heat', '__init__.py')):
sys.path.insert(0, POSSIBLE_TOPDIR) sys.path.insert(0, POSSIBLE_TOPDIR)
from oslo.config import cfg from oslo.config import cfg
from heat.common import notify from heat.common import notify
@ -41,7 +40,8 @@ from heat.openstack.common import log as logging
from heat.openstack.common import service from heat.openstack.common import service
from heat.rpc import api as rpc_api from heat.rpc import api as rpc_api
gettextutils.install('heat', lazy=False) gettextutils.enable_lazy()
gettextutils.install('heat', lazy=True)
LOG = logging.getLogger('heat.engine') LOG = logging.getLogger('heat.engine')

View File

@ -118,6 +118,9 @@ class FaultWrapper(wsgi.Middleware):
msg_trace = traceback.format_exc() msg_trace = traceback.format_exc()
message = full_message message = full_message
if isinstance(ex, exception.HeatException):
message = ex.message
if cfg.CONF.debug and not trace: if cfg.CONF.debug and not trace:
trace = msg_trace trace = msg_trace

View File

@ -719,7 +719,11 @@ def log_exception(err, exc_info):
def translate_exception(exc, locale): def translate_exception(exc, locale):
"""Translates all translatable elements of the given exception.""" """Translates all translatable elements of the given exception."""
exc.message = gettextutils.translate(six.text_type(exc), locale) if isinstance(exc, exception.HeatException):
exc.message = gettextutils.translate(exc.message, locale)
else:
exc.message = gettextutils.translate(six.text_type(exc), locale)
if isinstance(exc, webob.exc.HTTPError): if isinstance(exc, webob.exc.HTTPError):
# If the explanation is not a Message, that means that the # If the explanation is not a Message, that means that the
# explanation is the default, generic and not translatable explanation # explanation is the default, generic and not translatable explanation