IdHub/idhub/views.py

128 lines
4.5 KiB
Python
Raw Normal View History

2024-01-19 09:59:35 +00:00
import uuid
2024-02-02 14:40:52 +00:00
import logging
2024-01-19 19:37:17 +00:00
2024-01-17 11:40:54 +00:00
from django.conf import settings
2024-01-03 18:53:11 +00:00
from django.core.cache import cache
2024-01-19 19:37:17 +00:00
from django.urls import reverse_lazy
from django.views.generic.base import TemplateView
2023-10-09 08:49:56 +00:00
from django.contrib.auth import views as auth_views
2023-11-21 14:20:15 +00:00
from django.contrib.auth import login as auth_login
2024-01-19 19:37:17 +00:00
from django.utils.translation import gettext_lazy as _
from django.shortcuts import get_object_or_404, redirect
from django.contrib.auth.mixins import LoginRequiredMixin
from django.http import HttpResponseRedirect, HttpResponse, Http404
2024-01-15 09:34:42 +00:00
from idhub.models import DID
2024-01-19 19:37:17 +00:00
from idhub.email.views import NotifyActivateUserByEmail
2024-01-15 09:34:42 +00:00
from trustchain_idhub import settings
2023-09-28 09:01:14 +00:00
2024-02-02 14:40:52 +00:00
logger = logging.getLogger(__name__)
2023-10-09 08:49:56 +00:00
class LoginView(auth_views.LoginView):
2023-09-29 16:06:17 +00:00
template_name = 'auth/login.html'
extra_context = {
'title': _('Login'),
2023-10-09 08:49:56 +00:00
'success_url': reverse_lazy('idhub:user_dashboard'),
2023-09-29 16:06:17 +00:00
}
2023-09-28 09:01:14 +00:00
2023-10-16 17:08:18 +00:00
def get(self, request, *args, **kwargs):
2024-01-12 16:22:28 +00:00
self.extra_context['success_url'] = request.GET.get(
'next',
reverse_lazy('idhub:user_dashboard')
)
2024-01-30 18:35:29 +00:00
if not self.request.user.is_anonymous:
if self.request.user.is_admin:
return redirect(reverse_lazy('idhub:admin_dashboard'))
else:
return redirect(reverse_lazy('idhub:user_dashboard'))
2023-10-16 17:08:18 +00:00
return super().get(request, *args, **kwargs)
2023-11-21 14:20:15 +00:00
def form_valid(self, form):
user = form.get_user()
2024-01-03 19:14:04 +00:00
password = form.cleaned_data.get("password")
2024-01-06 18:18:59 +00:00
auth_login(self.request, user)
2024-01-04 11:43:24 +00:00
sensitive_data_encryption_key = user.decrypt_sensitive_data(password)
2024-01-06 18:18:59 +00:00
2023-11-21 14:20:15 +00:00
if not user.is_anonymous and user.is_admin:
admin_dashboard = reverse_lazy('idhub:admin_dashboard')
2024-01-12 16:22:28 +00:00
self.extra_context['success_url'] = admin_dashboard
2024-01-17 12:43:40 +00:00
# encryption_key = user.encrypt_data(
# sensitive_data_encryption_key,
# settings.SECRET_KEY
# )
# cache.set("KEY_DIDS", encryption_key, None)
cache.set("KEY_DIDS", sensitive_data_encryption_key, None)
2024-01-19 19:37:17 +00:00
if not settings.DEVELOPMENT:
self.request.session["2fauth"] = str(uuid.uuid4())
return redirect(reverse_lazy('idhub:confirm_send_2f'))
2024-01-03 19:14:04 +00:00
2024-01-06 18:18:59 +00:00
self.request.session["key_did"] = user.encrypt_data(
sensitive_data_encryption_key,
user.password+self.request.session._session_key
)
2023-11-21 14:20:15 +00:00
return HttpResponseRedirect(self.extra_context['success_url'])
2024-01-15 09:34:42 +00:00
2024-01-04 11:43:24 +00:00
class PasswordResetConfirmView(auth_views.PasswordResetConfirmView):
template_name = 'auth/password_reset_confirm.html'
success_url = reverse_lazy('idhub:password_reset_complete')
def form_valid(self, form):
2024-02-02 14:40:52 +00:00
password = form.cleaned_data.get("new_password1")
user = form.user
user.set_password(password)
2024-01-04 11:43:24 +00:00
user.set_encrypted_sensitive_data(password)
user.save()
return HttpResponseRedirect(self.success_url)
2024-01-17 13:11:47 +00:00
2024-02-02 14:40:52 +00:00
class PasswordResetView(auth_views.PasswordResetView):
template_name = 'auth/password_reset.html'
email_template_name = 'auth/password_reset_email.txt'
html_email_template_name = 'auth/password_reset_email.html'
subject_template_name = 'auth/password_reset_subject.txt'
success_url = reverse_lazy('idhub:password_reset_done')
def form_valid(self, form):
try:
return super().form_valid(form)
except Exception as err:
logger.error(err)
# url_error = reverse_lazy('idhub:password_reset_error')
# return HttpResponseRedirect(url_error)
return HttpResponseRedirect(self.success_url)
2024-01-15 09:34:42 +00:00
def serve_did(request, did_id):
2024-01-16 13:00:59 +00:00
id_did = f'did:web:{settings.DOMAIN}:did-registry:{did_id}'
did = get_object_or_404(DID, did=id_did)
document = did.didweb_document
2024-01-15 09:34:42 +00:00
retval = HttpResponse(document)
retval.headers["Content-Type"] = "application/json"
return retval
2024-01-19 19:37:17 +00:00
class DobleFactorSendView(LoginRequiredMixin, NotifyActivateUserByEmail, TemplateView):
template_name = 'auth/2fadmin.html'
subject_template_name = 'auth/2fadmin_email_subject.txt'
email_template_name = 'auth/2fadmin_email.txt'
html_email_template_name = 'auth/2fadmin_email.html'
def get(self, request, *args, **kwargs):
if not request.user.is_admin:
raise Http404
f2auth = self.request.session.get("2fauth")
if not f2auth:
raise Http404
self.send_email(self.request.user, token=f2auth)
return super().get(request, *args, **kwargs)