/
user_settings_view.py
127 lines (109 loc) · 4.83 KB
/
user_settings_view.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
from __future__ import annotations
import logging
from typing import TYPE_CHECKING
from django.contrib import messages
from django.contrib.auth import update_session_auth_hash
from django.shortcuts import redirect, render
from django.utils.translation import gettext_lazy as _
from django.views.generic import TemplateView
from ...forms import UserEmailForm, UserPasswordForm, UserPreferencesForm
if TYPE_CHECKING:
from typing import Any
from django.http import HttpRequest, HttpResponseRedirect
logger = logging.getLogger(__name__)
class UserSettingsView(TemplateView):
"""
View for the individual account settings
"""
#: The template to render (see :class:`~django.views.generic.base.TemplateResponseMixin`)
template_name = "settings/user_settings.html"
def get_context_data(self, **kwargs: Any) -> dict[str, Any]:
r"""
Returns a dictionary representing the template context
(see :meth:`~django.views.generic.base.ContextMixin.get_context_data`).
:param \**kwargs: The given keyword arguments
:return: The template context
"""
context = super().get_context_data(**kwargs)
context.update(
{
"keys": self.request.user.fido_keys.all(),
"user_email_form": UserEmailForm(instance=self.request.user),
"user_password_form": UserPasswordForm(instance=self.request.user),
"user_preferences_form": UserPreferencesForm(
instance=self.request.user
),
}
)
return context
def post(
self, request: HttpRequest, *args: Any, **kwargs: Any
) -> HttpResponseRedirect:
r"""
Submit :class:`~integreat_cms.cms.forms.users.user_email_form.UserEmailForm` and
:class:`~integreat_cms.cms.forms.users.user_password_form.UserPasswordForm` and save :class:`~django.contrib.auth.models.User`
object
:param request: The current request
:param \*args: The supplied arguments
:param \**kwargs: The supplied keyword arguments
:return: The rendered template response
"""
region = request.region
user = request.user
if request.POST.get("submit_form") == "email_form":
user_email_form = UserEmailForm(data=request.POST, instance=user)
if not user_email_form.is_valid():
user_email_form.add_error_messages(request)
return render(
request,
self.template_name,
{
**self.get_context_data(**kwargs),
"user_email_form": user_email_form,
},
)
if not user_email_form.has_changed():
messages.info(request, _("No changes made"))
else:
user_email_form.save()
messages.success(request, _("E-mail-address was successfully saved"))
elif request.POST.get("submit_form") == "password_form":
user_password_form = UserPasswordForm(data=request.POST, instance=user)
if not user_password_form.is_valid():
user_password_form.add_error_messages(request)
return render(
request,
self.template_name,
{
**self.get_context_data(**kwargs),
"user_password_form": user_password_form,
},
)
if not user_password_form.has_changed():
messages.info(request, _("No changes made"))
else:
user = user_password_form.save()
# Prevent user from being logged out after password has changed
update_session_auth_hash(request, user)
messages.success(request, _("Password was successfully saved"))
elif request.POST.get("submit_form") == "preferences_form":
user_preferences_form = UserPreferencesForm(
data=request.POST, instance=user
)
if not user_preferences_form.is_valid():
user_preferences_form.add_error_messages(request)
return render(
request,
self.template_name,
{
**self.get_context_data(**kwargs),
"user_preferences_form": user_preferences_form,
},
)
if not user_preferences_form.has_changed():
messages.info(request, _("No changes made"))
else:
user_preferences_form.save()
messages.success(request, _("Preferences were successfully saved"))
kwargs = {"region_slug": region.slug} if region else {}
return redirect("user_settings", **kwargs)