123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 |
- from django import forms
- from django.contrib.auth import get_user_model
- from django.contrib.auth.password_validation import validate_password
- from django.core.exceptions import ValidationError
- from django.utils.translation import ugettext as _
- from misago.users import validators
- from misago.users.bans import get_email_ban, get_ip_ban, get_username_ban
- UserModel = get_user_model()
- class BaseRegisterForm(forms.Form):
- def __init__(self, *args, **kwargs):
- self.agreements = kwargs.pop('agreements')
- self.request = kwargs.pop('request')
- super(BaseRegisterForm, self).__init__(*args, **kwargs)
- def clean_username(self):
- data = self.cleaned_data['username']
- ban = get_username_ban(data, registration_only=True)
- if ban:
- if ban.user_message:
- raise ValidationError(ban.user_message)
- else:
- raise ValidationError(_("This usernane is not allowed."))
- return data
- def clean_email(self):
- data = self.cleaned_data['email']
- ban = get_email_ban(data, registration_only=True)
- if ban:
- if ban.user_message:
- raise ValidationError(ban.user_message)
- else:
- raise ValidationError(_("This e-mail address is not allowed."))
- return data
- def clean_agreements(self, data):
- for field_name, agreement in self.agreements.items():
- if data.get(field_name) != agreement['id']:
- error = ValueError(_("This agreement is required."))
- self.add_error(field_name, error)
- def raise_if_ip_banned(self):
- ban = get_ip_ban(self.request.user_ip, registration_only=True)
- if ban:
- if ban.user_message:
- raise ValidationError(ban.user_message)
- else:
- raise ValidationError(_("New registrations from this IP address are not allowed."))
- class SocialAuthRegisterForm(BaseRegisterForm):
- username = forms.CharField(validators=[validators.validate_username])
- email = forms.CharField(validators=[validators.validate_email])
- terms_of_service = forms.IntegerField(required=False)
- privacy_policy = forms.IntegerField(required=False)
- def clean(self):
- cleaned_data = super(SocialAuthRegisterForm, self).clean()
- self.clean_agreements(cleaned_data)
- self.raise_if_ip_banned()
- validators.validate_new_registration(self.request, cleaned_data, self)
- return cleaned_data
- class RegisterForm(BaseRegisterForm):
- username = forms.CharField(validators=[validators.validate_username])
- email = forms.CharField(validators=[validators.validate_email])
- password = forms.CharField(strip=False)
- terms_of_service = forms.IntegerField(required=False)
- privacy_policy = forms.IntegerField(required=False)
- # placeholder field for setting captcha errors on form
- captcha = forms.CharField(required=False)
- def full_clean_password(self, cleaned_data):
- if cleaned_data.get('password'):
- validate_password(
- cleaned_data['password'],
- user=UserModel(
- username=cleaned_data.get('username'),
- email=cleaned_data.get('email'),
- ),
- )
- def clean(self):
- cleaned_data = super(RegisterForm, self).clean()
- self.clean_agreements(cleaned_data)
- self.raise_if_ip_banned()
- try:
- self.full_clean_password(cleaned_data)
- except forms.ValidationError as e:
- self.add_error('password', e)
- validators.validate_new_registration(self.request, cleaned_data, self.add_error)
- return cleaned_data
|