61 lines
1.9 KiB
Python
61 lines
1.9 KiB
Python
from django import forms
|
|
from django.contrib.auth import (
|
|
password_validation,
|
|
)
|
|
from django.utils.translation import gettext_lazy as _
|
|
from utils import exceptions
|
|
|
|
|
|
class SetPasswordForm(forms.Form):
|
|
"""
|
|
A form that lets a user change set their password without entering the old
|
|
password
|
|
"""
|
|
error_messages = {
|
|
'password_mismatch': _("The two password fields didn't match."),
|
|
'password_equal': _("Password already in use."),
|
|
}
|
|
new_password1 = forms.CharField(
|
|
label=_("New password"),
|
|
widget=forms.PasswordInput,
|
|
strip=False,
|
|
help_text=password_validation.password_validators_help_text_html(),
|
|
)
|
|
new_password2 = forms.CharField(
|
|
label=_("New password confirmation"),
|
|
strip=False,
|
|
widget=forms.PasswordInput,
|
|
)
|
|
|
|
def __init__(self, user, *args, **kwargs):
|
|
self.user = user
|
|
super().__init__(*args, **kwargs)
|
|
|
|
def clean_new_password1(self):
|
|
password1 = self.cleaned_data.get('new_password1')
|
|
if self.user.check_password(password1):
|
|
raise forms.ValidationError(
|
|
self.error_messages['password_equal'],
|
|
code='password_equal',
|
|
)
|
|
return password1
|
|
|
|
def clean_new_password2(self):
|
|
password1 = self.cleaned_data.get('new_password1')
|
|
password2 = self.cleaned_data.get('new_password2')
|
|
if password1 and password2:
|
|
if password1 != password2:
|
|
raise forms.ValidationError(
|
|
self.error_messages['password_mismatch'],
|
|
code='password_mismatch',
|
|
)
|
|
password_validation.validate_password(password2, self.user)
|
|
return password2
|
|
|
|
def save(self, commit=True):
|
|
password = self.cleaned_data["new_password1"]
|
|
self.user.set_password(password)
|
|
if commit:
|
|
self.user.save()
|
|
return self.user
|