register.py 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. from django import forms
  2. from django.contrib.auth import get_user_model
  3. from django.contrib.auth.password_validation import validate_password
  4. from django.core.exceptions import ValidationError
  5. from django.utils.translation import ugettext as _
  6. from misago.users import validators
  7. from misago.users.bans import get_email_ban, get_ip_ban, get_username_ban
  8. UserModel = get_user_model()
  9. class BaseRegisterForm(forms.Form):
  10. username = forms.CharField(validators=[validators.validate_username])
  11. email = forms.CharField(validators=[validators.validate_email])
  12. terms_of_service = forms.IntegerField(required=False)
  13. privacy_policy = forms.IntegerField(required=False)
  14. def __init__(self, *args, **kwargs):
  15. self.agreements = kwargs.pop('agreements')
  16. self.request = kwargs.pop('request')
  17. super(BaseRegisterForm, self).__init__(*args, **kwargs)
  18. def clean_username(self):
  19. data = self.cleaned_data['username']
  20. ban = get_username_ban(data, registration_only=True)
  21. if ban:
  22. if ban.user_message:
  23. raise ValidationError(ban.user_message)
  24. else:
  25. raise ValidationError(_("This usernane is not allowed."))
  26. return data
  27. def clean_email(self):
  28. data = self.cleaned_data['email']
  29. ban = get_email_ban(data, registration_only=True)
  30. if ban:
  31. if ban.user_message:
  32. raise ValidationError(ban.user_message)
  33. else:
  34. raise ValidationError(_("This e-mail address is not allowed."))
  35. return data
  36. def clean_agreements(self, data):
  37. for field_name, agreement in self.agreements.items():
  38. if data.get(field_name) != agreement['id']:
  39. error = ValueError(_("This agreement is required."))
  40. self.add_error(field_name, error)
  41. def raise_if_ip_banned(self):
  42. ban = get_ip_ban(self.request.user_ip, registration_only=True)
  43. if ban:
  44. if ban.user_message:
  45. raise ValidationError(ban.user_message)
  46. else:
  47. raise ValidationError(_("New registrations from this IP address are not allowed."))
  48. class SocialAuthRegisterForm(BaseRegisterForm):
  49. def clean(self):
  50. cleaned_data = super(SocialAuthRegisterForm, self).clean()
  51. self.clean_agreements(cleaned_data)
  52. self.raise_if_ip_banned()
  53. validators.validate_new_registration(self.request, cleaned_data, self)
  54. return cleaned_data
  55. class RegisterForm(BaseRegisterForm):
  56. password = forms.CharField(strip=False)
  57. # placeholder field for setting captcha errors on form
  58. captcha = forms.CharField(required=False)
  59. def full_clean_password(self, cleaned_data):
  60. if cleaned_data.get('password'):
  61. validate_password(
  62. cleaned_data['password'],
  63. user=UserModel(
  64. username=cleaned_data.get('username'),
  65. email=cleaned_data.get('email'),
  66. ),
  67. )
  68. def clean(self):
  69. cleaned_data = super(RegisterForm, self).clean()
  70. self.clean_agreements(cleaned_data)
  71. self.raise_if_ip_banned()
  72. try:
  73. self.full_clean_password(cleaned_data)
  74. except forms.ValidationError as e:
  75. self.add_error('password', e)
  76. validators.validate_new_registration(self.request, cleaned_data, self.add_error)
  77. return cleaned_data