IdHub/idhub/mixins.py

58 lines
1.7 KiB
Python
Raw Normal View History

2023-10-09 09:44:26 +00:00
from django.contrib.auth.mixins import LoginRequiredMixin
from django.contrib.auth import views as auth_views
2023-10-09 11:43:34 +00:00
from django.urls import reverse_lazy, resolve
2023-10-09 09:44:26 +00:00
from django.utils.translation import gettext_lazy as _
from django.shortcuts import redirect
2024-01-20 11:26:19 +00:00
from django.http import Http404
from django.core.exceptions import PermissionDenied
class Http403(PermissionDenied):
status_code = 403
default_detail = _('Permission denied. User is not authenticated')
default_code = 'forbidden'
def __init__(self, detail=None, code=None):
if detail is not None:
self.detail = details or self.default_details
if code is not None:
self.code = code or self.default_code
2023-10-09 09:44:26 +00:00
2023-10-11 07:52:05 +00:00
class UserView(LoginRequiredMixin):
2023-10-09 09:44:26 +00:00
login_url = "/login/"
2023-10-09 16:38:28 +00:00
wallet = False
2023-10-09 09:44:26 +00:00
def get_context_data(self, **kwargs):
context = super().get_context_data(**kwargs)
context.update({
'title': self.title,
2023-10-09 11:43:34 +00:00
'subtitle': self.subtitle,
'icon': self.icon,
'section': self.section,
'path': resolve(self.request.path).url_name,
2023-10-09 16:38:28 +00:00
'user': self.request.user,
'wallet': self.wallet,
2023-10-09 09:44:26 +00:00
})
return context
class AdminView(UserView):
2023-10-11 16:08:20 +00:00
def get(self, request, *args, **kwargs):
2024-01-20 11:26:19 +00:00
self.check_valid_user()
return super().get(request, *args, **kwargs)
2023-10-09 09:44:26 +00:00
2024-01-20 11:26:19 +00:00
def post(self, request, *args, **kwargs):
self.check_valid_user()
return super().post(request, *args, **kwargs)
2024-01-19 09:59:35 +00:00
2024-01-20 11:26:19 +00:00
def check_valid_user(self):
if not self.request.user.is_admin:
raise Http403
if self.request.session.get("2fauth"):
raise Http403