errorpages.py 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. from django.shortcuts import redirect
  2. from misago.admin.auth import is_admin_session, update_admin_session
  3. from misago.admin.views import get_protected_namespace, protected_admin_view, render
  4. # Magic error page used by admin
  5. @protected_admin_view
  6. def _error_page(request, code, message=None):
  7. if is_admin_session(request):
  8. template_pattern = 'misago/admin/errorpages/%s.html' % code
  9. response = render(request,
  10. template_pattern,
  11. {'message': message},
  12. error_page=True)
  13. response.status_code = code
  14. return response
  15. else:
  16. return redirect('misago:admin:index')
  17. def admin_error_page(f):
  18. def decorator(request, *args, **kwargs):
  19. if get_protected_namespace(request):
  20. update_admin_session(request)
  21. return _error_page(request, *args, **kwargs)
  22. else:
  23. return f(request, *args, **kwargs)
  24. return decorator
  25. # Magic CSRF fail page for Admin
  26. def _csrf_failure(request, reason=""):
  27. if is_admin_session(request):
  28. update_admin_session(request)
  29. response = render(
  30. request, 'misago/admin/errorpages/csrf_failure_authenticated.html',
  31. error_page=True)
  32. else:
  33. response = render(request, 'misago/admin/errorpages/csrf_failure.html')
  34. response.status_code = 403
  35. return response
  36. def admin_csrf_failure(f):
  37. def decorator(request, *args, **kwargs):
  38. if get_protected_namespace(request):
  39. return _csrf_failure(request, *args, **kwargs)
  40. else:
  41. return f(request, *args, **kwargs)
  42. return decorator