diff options
author | Sebastian Spaeth <Sebastian@SSpaeth.de> | 2012-11-29 08:57:12 +0100 |
---|---|---|
committer | Sebastian Spaeth <Sebastian@SSpaeth.de> | 2012-11-29 09:01:08 +0100 |
commit | 6b5f1ca79b42b977ea5f436ac7ab329fd2da1b6b (patch) | |
tree | a687adb129f8e45dcf5ec66463532a9ceb753ac9 | |
parent | efb70b529f3c04054e4453144155b18a8400281b (diff) | |
download | mediagoblin-6b5f1ca79b42b977ea5f436ac7ab329fd2da1b6b.tar.lz mediagoblin-6b5f1ca79b42b977ea5f436ac7ab329fd2da1b6b.tar.xz mediagoblin-6b5f1ca79b42b977ea5f436ac7ab329fd2da1b6b.zip |
Implement generic error pages
Rather than having a 404.html, a 403.html, a 500.html,...
we have a generic error.html template that we pass in an
error code, a title and a (html'ish) error message.
Implement the common render_404 and render_403 shortcuts. More exotic
cases can be achieved by the generic render_error function.
Signed-off-by: Sebastian Spaeth <Sebastian@SSpaeth.de>
-rw-r--r-- | mediagoblin/templates/mediagoblin/error.html (renamed from mediagoblin/templates/mediagoblin/404.html) | 11 | ||||
-rw-r--r-- | mediagoblin/tools/response.py | 31 |
2 files changed, 30 insertions, 12 deletions
diff --git a/mediagoblin/templates/mediagoblin/404.html b/mediagoblin/templates/mediagoblin/error.html index c0fe8b62..c16b650f 100644 --- a/mediagoblin/templates/mediagoblin/404.html +++ b/mediagoblin/templates/mediagoblin/error.html @@ -17,15 +17,12 @@ #} {% extends "mediagoblin/base.html" %} -{% block title %}404 — {{ super() }}{% endblock %} +{% block title %}{{err_code}} — {{ super() }}{% endblock %} {% block mediagoblin_content %} <img class="right_align" src="{{ request.staticdirect('/images/404.png') }}" - alt="{% trans %}Image of 404 goblin stressing out{% endtrans %}" /> - <h1>{% trans %}Oops!{% endtrans %}</h1> - <p>{% trans %}There doesn't seem to be a page at this address. Sorry!{% endtrans %}</p> - <p> - {%- trans %}If you're sure the address is correct, maybe the page you're looking for has been moved or deleted.{% endtrans -%} - </p> + alt="{% trans %}Image of goblin stressing out{% endtrans %}" /> + <h1>{{ title }}</h1> + <p>{{ err_msg|safe }}</p> <div class="clear"></div> {% endblock %} diff --git a/mediagoblin/tools/response.py b/mediagoblin/tools/response.py index a54c32fb..a77f68b9 100644 --- a/mediagoblin/tools/response.py +++ b/mediagoblin/tools/response.py @@ -16,6 +16,7 @@ from webob import Response, exc from mediagoblin.tools.template import render_template +from mediagoblin.tools.translate import fake_ugettext_passthrough as _ def render_to_response(request, template, context, status=200): @@ -25,14 +26,34 @@ def render_to_response(request, template, context, status=200): status=status) -def render_404(request): - """ - Render a 404. +def render_error(request, status=500, title=_('Oops!'), + err_msg=_('An error occured')): + """Render any error page with a given error code, title and text body + + Title and description are passed through as-is to allow html. Make + sure no user input is contained therein for security reasons. The + description will be wrapped in a <p> tag. """ - return render_to_response( - request, 'mediagoblin/404.html', {}, status=404) + return Response(render_template(request, 'mediagoblin/error.html', + {'err_code': status, 'title': title, 'err_msg': err_msg}), + status=status) +def render_403(request): + """Render a standard 403 page""" + title = _('Operation not allowed') + err_msg = _("Sorry Dave, I can't let you do that!</p><p>You have tried " + " to perform a function that you are not allowed to. Have you " + "been trying to delete all user accounts again?") + return render_error(request, 403, title, err_msg) + +def render_404(request): + """Render a standard 404 page.""" + err_msg = _("<p>There doesn't seem to be a page at this address. Sorry!</p>" + "<p>If you're sure the address is correct, maybe the page " + "you're looking for has been moved or deleted.") + return render_error(request, 404, err_msg=err_msg) + def redirect(request, *args, **kwargs): """Returns a HTTPFound(), takes a request and then urlgen params""" |