1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- from django.shortcuts import redirect
- from misago.admin.auth import is_admin_session, update_admin_session
- from misago.admin.views import get_protected_namespace, protected_admin_view, render
- # Magic error page used by admin
- @protected_admin_view
- def _error_page(request, code, message=None):
- if is_admin_session(request):
- template_pattern = 'misago/admin/errorpages/%s.html' % code
- response = render(request,
- template_pattern,
- {'message': message},
- error_page=True)
- response.status_code = code
- return response
- else:
- return redirect('misago:admin:index')
- def admin_error_page(f):
- def decorator(request, *args, **kwargs):
- if get_protected_namespace(request):
- update_admin_session(request)
- return _error_page(request, *args, **kwargs)
- else:
- return f(request, *args, **kwargs)
- return decorator
- # Magic CSRF fail page for Admin
- def _csrf_failure(request, reason=""):
- if is_admin_session(request):
- update_admin_session(request)
- response = render(
- request, 'misago/admin/errorpages/csrf_failure_authenticated.html',
- error_page=True)
- else:
- response = render(request, 'misago/admin/errorpages/csrf_failure.html')
- response.status_code = 403
- return response
- def admin_csrf_failure(f):
- def decorator(request, *args, **kwargs):
- if get_protected_namespace(request):
- return _csrf_failure(request, *args, **kwargs)
- else:
- return f(request, *args, **kwargs)
- return decorator
|