Skip to content

Commit

Permalink
Merge pull request #958 from deepthivenkat/Issue#929
Browse files Browse the repository at this point in the history
Fix #929 - Make Error management more DRY
  • Loading branch information
karlcow committed Apr 15, 2016
2 parents 9a40c61 + aeeaff0 commit 6269b77
Show file tree
Hide file tree
Showing 2 changed files with 38 additions and 81 deletions.
1 change: 1 addition & 0 deletions tests/test_urls.py
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@ def test_login(self):
self.assertIn('github.com/login/oauth/', rv.headers['Location'])

def test_activity_page_401_if_not_logged_in(self):
'''Test that asks user to log in before displaying activity.'''
rv = self.app.get('/me')
self.assertEqual(rv.status_code, 401)

Expand Down
118 changes: 37 additions & 81 deletions webcompat/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@
import json
import urllib

from flask.ext.github import GitHubError
from flask import abort
from flask import flash
from flask import g
Expand Down Expand Up @@ -38,6 +37,15 @@
from webcompat.api.uploads import upload


ERROR_DICT = {400: 'Bad Request.',
401: 'Unauthorized. Please log in.',
403: 'Forbidden. Maybe that looking at private stuff?',
404: 'Not Found. Lost in Punk Cat Space',
429: 'Cool your jets! Please wait {0} seconds before making '
'another search.',
500: 'Internal Server Error'}


@app.teardown_appcontext
def shutdown_session(exception=None):
session_db.remove()
Expand Down Expand Up @@ -287,84 +295,39 @@ def cssfixme():
return render_template('cssfixme.html')


@app.errorhandler(GitHubError)
def jumpship(e):
print('jumpship! ', e)
session.pop('user_id', None)
flash('Something bad happened. Please try again?', 'error')
return redirect(url_for('index'))


@app.errorhandler(400)
def bad_request_status(err):
message = 'Bad Request.'
if (request.path.startswith('/api/') and
request.accept_mimetypes.accept_json and
not request.accept_mimetypes.accept_html):
message = {
'status': 400,
'message': 'API call. ' + message,
}
resp = jsonify(message)
resp.status_code = 400
return resp
return render_template('error.html',
error_code=400,
error_message=message), 400


@app.errorhandler(401)
def unauthorized_status(err):
message = 'Unauthorized. Please log in.'
if (request.path.startswith('/api/') and
request.accept_mimetypes.accept_json and
not request.accept_mimetypes.accept_html):
message = {
'status': 401,
'message': 'API call. ' + message,
}
resp = jsonify(message)
resp.status_code = 401
return resp
return render_template('error.html',
error_code=401,
error_message=message), 401
@app.errorhandler(403)
@app.errorhandler(404)
@app.errorhandler(500)
def custom_error_handler(err):
if api_call(request):
return api_message(err.code)
return render_template(
'error.html',
error_code=err.code,
error_message=ERROR_DICT[err.code]), err.code


@app.errorhandler(403)
def forbidden_status(err):
message = 'Forbidden. Are you trying to look at someone else\'s stuff?'
def api_call(request):
'''Checks if it's an API call'''
if (request.path.startswith('/api/') and
request.accept_mimetypes.accept_json and
not request.accept_mimetypes.accept_html):
message = {
'status': 403,
'message': 'API call. ' + message,
}
resp = jsonify(message)
resp.status_code = 403
return resp
return render_template('error.html',
error_code=403,
error_message=message), 403
return True
else:
return False


@app.errorhandler(404)
def not_found_status(err):
if (request.path.startswith('/api/') and
request.accept_mimetypes.accept_json and
not request.accept_mimetypes.accept_html):
message = {
'status': 404,
'message': 'API call. Not Found',
}
resp = jsonify(message)
resp.status_code = 404
return resp
message = "We can't find what you are looking for."
return render_template('error.html',
error_code=404,
error_message=message), 404
def api_message(code):
'''Prepares HTTP response for API calls.'''
message = {
'status': code,
'message': ERROR_DICT[code],
}
resp = jsonify(message)
resp.status_code = code
return resp


@app.errorhandler(429)
Expand All @@ -379,15 +342,8 @@ def too_many_requests_status(err):
# TODO: determine actual time left.
# TODO: send message with login link.
time_left = 60
message = ('Cool your jets! Please wait {0} seconds before making'
' another search.').format(time_left)
message = (ERROR_DICT[err.code]).format(time_left)
error_data = {'message': message, 'timeout': 5}
return (json.dumps(error_data), 429, {'content-type': 'application/json'})


@app.errorhandler(500)
def internal_server_error_status(err):
message = "Internal Server Error"
return render_template('error.html',
error_code=500,
error_message=message), 500
resp = jsonify(error_data)
resp.status_code = err.code
return resp

0 comments on commit 6269b77

Please sign in to comment.