Commit 6b0f04d5 authored by Hanno Schlichting's avatar Hanno Schlichting

Pass Unauthorized exception into `response._unauthorized`.

parent 9a7a13bf
...@@ -149,8 +149,9 @@ class WSGIResponse(HTTPResponse): ...@@ -149,8 +149,9 @@ class WSGIResponse(HTTPResponse):
result.extend(HTTPResponse.listHeaders(self)) result.extend(HTTPResponse.listHeaders(self))
return result return result
def _unauthorized(self): def _unauthorized(self, exc=None):
self.setStatus(401) status = exc.getStatus() if exc is not None else 401
self.setStatus(status)
if self.realm: if self.realm:
self.setHeader('WWW-Authenticate', self.setHeader('WWW-Authenticate',
'basic realm="%s"' % self.realm, 1) 'basic realm="%s"' % self.realm, 1)
...@@ -266,8 +267,8 @@ def _publish_wsgi(request, response, module_info, start_response, stdout, ...@@ -266,8 +267,8 @@ def _publish_wsgi(request, response, module_info, start_response, stdout,
try: try:
with transaction_pubevents(request): with transaction_pubevents(request):
response = _publish(request, module_info) response = _publish(request, module_info)
except Unauthorized: except Unauthorized as exc:
response._unauthorized() response._unauthorized(exc)
except HTTPRedirection as exc: except HTTPRedirection as exc:
# TODO: HTTPOk is only handled by the httpexceptions # TODO: HTTPOk is only handled by the httpexceptions
# middleware, maybe it should be handled here. # middleware, maybe it should be handled here.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment