Externalize error messages in the API
This patch does more internationalization for the REST API error messages that don't currently have it to take advantage of the new support added by bp user-locale-api to show error messages in the locale requested by the user through the Accept-Language HTTP header. Partially implements bp user-locale-api Change-Id: I92780b42c125a91ab4916b7a31e4b71d306a89a1
This commit is contained in:
parent
d12fcadaa0
commit
f3708c1d09
@ -249,10 +249,12 @@ class ExtensionController(wsgi.Controller):
|
|||||||
return dict(extension=self._translate(ext))
|
return dict(extension=self._translate(ext))
|
||||||
|
|
||||||
def delete(self, request, id):
|
def delete(self, request, id):
|
||||||
raise webob.exc.HTTPNotFound()
|
msg = _('Resource not found.')
|
||||||
|
raise webob.exc.HTTPNotFound(msg)
|
||||||
|
|
||||||
def create(self, request):
|
def create(self, request):
|
||||||
raise webob.exc.HTTPNotFound()
|
msg = _('Resource not found.')
|
||||||
|
raise webob.exc.HTTPNotFound(msg)
|
||||||
|
|
||||||
|
|
||||||
class ExtensionMiddleware(wsgi.Middleware):
|
class ExtensionMiddleware(wsgi.Middleware):
|
||||||
|
@ -170,7 +170,8 @@ class Controller(object):
|
|||||||
try:
|
try:
|
||||||
resource = self._item(request, id, True)
|
resource = self._item(request, id, True)
|
||||||
except exceptions.PolicyNotAuthorized:
|
except exceptions.PolicyNotAuthorized:
|
||||||
raise webob.exc.HTTPNotFound()
|
msg = _('The resource could not be found.')
|
||||||
|
raise webob.exc.HTTPNotFound(msg)
|
||||||
body = kwargs.pop('body', None)
|
body = kwargs.pop('body', None)
|
||||||
# Explicit comparison with None to distinguish from {}
|
# Explicit comparison with None to distinguish from {}
|
||||||
if body is not None:
|
if body is not None:
|
||||||
@ -291,7 +292,8 @@ class Controller(object):
|
|||||||
except exceptions.PolicyNotAuthorized:
|
except exceptions.PolicyNotAuthorized:
|
||||||
# To avoid giving away information, pretend that it
|
# To avoid giving away information, pretend that it
|
||||||
# doesn't exist
|
# doesn't exist
|
||||||
raise webob.exc.HTTPNotFound()
|
msg = _('The resource could not be found.')
|
||||||
|
raise webob.exc.HTTPNotFound(msg)
|
||||||
|
|
||||||
def _emulate_bulk_create(self, obj_creator, request, body, parent_id=None):
|
def _emulate_bulk_create(self, obj_creator, request, body, parent_id=None):
|
||||||
objs = []
|
objs = []
|
||||||
@ -423,7 +425,8 @@ class Controller(object):
|
|||||||
except exceptions.PolicyNotAuthorized:
|
except exceptions.PolicyNotAuthorized:
|
||||||
# To avoid giving away information, pretend that it
|
# To avoid giving away information, pretend that it
|
||||||
# doesn't exist
|
# doesn't exist
|
||||||
raise webob.exc.HTTPNotFound()
|
msg = _('The resource could not be found.')
|
||||||
|
raise webob.exc.HTTPNotFound(msg)
|
||||||
|
|
||||||
obj_deleter = getattr(self._plugin, action)
|
obj_deleter = getattr(self._plugin, action)
|
||||||
obj_deleter(request.context, id, **kwargs)
|
obj_deleter(request.context, id, **kwargs)
|
||||||
@ -473,7 +476,8 @@ class Controller(object):
|
|||||||
except exceptions.PolicyNotAuthorized:
|
except exceptions.PolicyNotAuthorized:
|
||||||
# To avoid giving away information, pretend that it
|
# To avoid giving away information, pretend that it
|
||||||
# doesn't exist
|
# doesn't exist
|
||||||
raise webob.exc.HTTPNotFound()
|
msg = _('The resource could not be found.')
|
||||||
|
raise webob.exc.HTTPNotFound(msg)
|
||||||
|
|
||||||
obj_updater = getattr(self._plugin, action)
|
obj_updater = getattr(self._plugin, action)
|
||||||
kwargs = {self._resource: body}
|
kwargs = {self._resource: body}
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
import webob.dec
|
import webob.dec
|
||||||
|
|
||||||
from neutron.api.views import versions as versions_view
|
from neutron.api.views import versions as versions_view
|
||||||
|
from neutron.openstack.common import gettextutils
|
||||||
from neutron.openstack.common import log as logging
|
from neutron.openstack.common import log as logging
|
||||||
from neutron import wsgi
|
from neutron import wsgi
|
||||||
|
|
||||||
@ -42,7 +43,10 @@ class Versions(object):
|
|||||||
]
|
]
|
||||||
|
|
||||||
if req.path != '/':
|
if req.path != '/':
|
||||||
return webob.exc.HTTPNotFound()
|
language = req.best_match_language()
|
||||||
|
msg = _('Unknown API version specified')
|
||||||
|
msg = gettextutils.get_localized_message(msg, language)
|
||||||
|
return webob.exc.HTTPNotFound(explanation=msg)
|
||||||
|
|
||||||
builder = versions_view.get_view_builder(req)
|
builder = versions_view.get_view_builder(req)
|
||||||
versions = [builder.build(version) for version in version_objs]
|
versions = [builder.build(version) for version in version_objs]
|
||||||
|
@ -66,7 +66,8 @@ class QuotaSetsController(wsgi.Controller):
|
|||||||
request.context, QUOTAS.resources, tenant_id)
|
request.context, QUOTAS.resources, tenant_id)
|
||||||
|
|
||||||
def create(self, request, body=None):
|
def create(self, request, body=None):
|
||||||
raise webob.exc.HTTPNotImplemented()
|
msg = _('POST requests are not supported on this resource.')
|
||||||
|
raise webob.exc.HTTPNotImplemented(msg)
|
||||||
|
|
||||||
def index(self, request):
|
def index(self, request):
|
||||||
context = request.context
|
context = request.context
|
||||||
|
@ -143,11 +143,13 @@ class ConfDriver(object):
|
|||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def delete_tenant_quota(context, tenant_id):
|
def delete_tenant_quota(context, tenant_id):
|
||||||
raise webob.exc.HTTPForbidden()
|
msg = _('Access to this resource was denied.')
|
||||||
|
raise webob.exc.HTTPForbidden(msg)
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def update_quota_limit(context, tenant_id, resource, limit):
|
def update_quota_limit(context, tenant_id, resource, limit):
|
||||||
raise webob.exc.HTTPForbidden()
|
msg = _('Access to this resource was denied.')
|
||||||
|
raise webob.exc.HTTPForbidden(msg)
|
||||||
|
|
||||||
|
|
||||||
class BaseResource(object):
|
class BaseResource(object):
|
||||||
|
@ -952,7 +952,7 @@ class Router(object):
|
|||||||
return self._router
|
return self._router
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
@webob.dec.wsgify
|
@webob.dec.wsgify(RequestClass=Request)
|
||||||
def _dispatch(req):
|
def _dispatch(req):
|
||||||
"""Dispatch a Request.
|
"""Dispatch a Request.
|
||||||
|
|
||||||
@ -962,7 +962,10 @@ class Router(object):
|
|||||||
"""
|
"""
|
||||||
match = req.environ['wsgiorg.routing_args'][1]
|
match = req.environ['wsgiorg.routing_args'][1]
|
||||||
if not match:
|
if not match:
|
||||||
return webob.exc.HTTPNotFound()
|
language = req.best_match_language()
|
||||||
|
msg = _('The resource could not be found.')
|
||||||
|
msg = gettextutils.get_localized_message(msg, language)
|
||||||
|
return webob.exc.HTTPNotFound(explanation=msg)
|
||||||
app = match['controller']
|
app = match['controller']
|
||||||
return app
|
return app
|
||||||
|
|
||||||
@ -1167,7 +1170,8 @@ class Controller(object):
|
|||||||
try:
|
try:
|
||||||
return serializer.serialize(data, content_type)
|
return serializer.serialize(data, content_type)
|
||||||
except exception.InvalidContentType:
|
except exception.InvalidContentType:
|
||||||
raise webob.exc.HTTPNotAcceptable()
|
msg = _('The requested content type %s is invalid.') % content_type
|
||||||
|
raise webob.exc.HTTPNotAcceptable(msg)
|
||||||
|
|
||||||
def _deserialize(self, data, content_type):
|
def _deserialize(self, data, content_type):
|
||||||
"""Deserialize the request body to the specefied content type.
|
"""Deserialize the request body to the specefied content type.
|
||||||
|
Loading…
Reference in New Issue
Block a user