This repository has been archived on 2020-03-24. You can view files and clone it, but cannot push or open issues or pull requests.
quay/util/http.py

33 lines
1.1 KiB
Python
Raw Normal View History

2014-01-24 20:09:35 +00:00
import logging
2014-01-24 20:10:51 +00:00
from flask import request, abort as flask_abort, make_response
from auth.auth import process_auth, extract_namespace_repo_from_session, get_authenticated_user, get_validated_token
2014-01-24 20:10:51 +00:00
from werkzeug.exceptions import HTTPException
2014-01-24 20:09:35 +00:00
logger = logging.getLogger(__name__)
DEFAULT_MESSAGE = {}
DEFAULT_MESSAGE[400] = 'Invalid Request'
DEFAULT_MESSAGE[403] = 'Forbidden'
DEFAULT_MESSAGE[404] = 'Not Found'
def abort(status_code, message=None, **kwargs):
if status_code == 403 and not message:
# Create a default error message for auth failure.
message = 'Forbidden. '
auth_user = get_authenticated_user()
auth_token = get_validated_token()
if auth_user:
2014-01-24 20:06:35 +00:00
message = message + 'Current user: ' + auth_user.username
elif auth_token:
2014-01-24 20:06:35 +00:00
message = message + 'Current token: ' + auth_token.friendly_name or auth_token.code
message = message % kwargs if message else DEFAULT_MESSAGE[status_code]
# Log the abort.
2014-01-24 20:09:35 +00:00
logger.error('Error %s: %s. Arguments: %s' % (status_code, message, request.view_args))
# Report the abort to the user.
flask_abort(make_response(HTTPException(message), status_code, headers))