errorpages.py 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. from django.http import JsonResponse
  2. from django.shortcuts import render
  3. from django.utils.translation import ugettext as _
  4. from misago.admin.views.errorpages import admin_csrf_failure, admin_error_page
  5. from .utils import is_request_to_misago
  6. def _ajax_error(code=406, message=None):
  7. return JsonResponse({'detail': message}, status=code)
  8. @admin_error_page
  9. def _error_page(request, code, message=None):
  10. request.frontend_context.update({
  11. 'CURRENT_LINK': 'misago:error-%s' % code
  12. })
  13. return render(request, 'misago/errorpages/%s.html' % code, {
  14. 'message': message
  15. }, status=code)
  16. def banned(request, ban):
  17. request.frontend_context.update({
  18. 'BAN_MESSAGE': ban.get_serialized_message(),
  19. 'CURRENT_LINK': 'misago:error-banned'
  20. })
  21. return render(request, 'misago/errorpages/banned.html', {
  22. 'ban': ban
  23. }, status=403)
  24. def permission_denied(request, message=None):
  25. if request.is_ajax():
  26. return _ajax_error(403, message or _("Permission denied."))
  27. else:
  28. return _error_page(request, 403, message)
  29. def page_not_found(request):
  30. if request.is_ajax():
  31. return _ajax_error(404, "Not found.")
  32. else:
  33. return _error_page(request, 404)
  34. @admin_csrf_failure
  35. def csrf_failure(request, reason=""):
  36. if request.is_ajax():
  37. return _ajax_error(403, _("Request authentication is invalid."))
  38. else:
  39. response = render(request, 'misago/errorpages/csrf_failure.html')
  40. response.status_code = 403
  41. return response
  42. def not_allowed(request):
  43. return _error_page(request, 405)
  44. # Decorators for custom error page handlers
  45. def shared_403_exception_handler(f):
  46. def page_decorator(request, *args, **kwargs):
  47. if is_request_to_misago(request):
  48. return permission_denied(request)
  49. else:
  50. return f(request, *args, **kwargs)
  51. return page_decorator
  52. def shared_404_exception_handler(f):
  53. def page_decorator(request, *args, **kwargs):
  54. if is_request_to_misago(request):
  55. return page_not_found(request)
  56. else:
  57. return f(request, *args, **kwargs)
  58. return page_decorator