register.py 3.4 KB

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