Merge "Use server supplied error strings"

This commit is contained in:
Zuul 2023-12-01 17:21:10 +00:00 committed by Gerrit Code Review
commit f58fe01d6d

View File

@ -90,16 +90,28 @@ class ZuulRESTClient(object):
def _check_request_status(self, req): def _check_request_status(self, req):
try: try:
req.raise_for_status() req.raise_for_status()
msg = None
except Exception as e: except Exception as e:
if req.status_code == 401: if req.status_code == 401:
raise ZuulRESTException( msg = \
'Unauthorized - your token might be invalid or expired.') 'Unauthorized - your token might be invalid or expired.'
elif req.status_code == 403: elif req.status_code == 403:
raise ZuulRESTException( msg = \
'Insufficient privileges to perform the action.') 'Insufficient privileges to perform the action.'
else: else:
raise ZuulRESTException( msg = \
'Unknown error code %s: "%s"' % (req.status_code, e)) 'Unknown error code %s: "%s"' % (req.status_code, e)
try:
doc = req.json()
msg = '%s: %s' % (doc['error'], doc['description'])
except Exception:
pass
# This is outside the above handler in order to suppress the
# original exception (this one will still have an appropriate
# traceback; we don't need both).
if msg:
raise ZuulRESTException(msg)
def _check_scope(self, tenant): def _check_scope(self, tenant):
scope = self.info.get("tenant", None) scope = self.info.get("tenant", None)