Browse Source

fix mail problems: check pseudo taken and lower)

crans_dev
Charlie Jacomme 7 years ago
committed by Gabriel Detraz
parent
commit
e1e2ccab9a
  1. 15
      users/models.py

15
users/models.py

@ -104,6 +104,13 @@ def linux_user_validator(login):
params={'label': login},
)
def pseudo_taken(login):
""" Retourne une erreur de validation si le login ne respecte
pas les contraintes unix (maj, min, chiffres ou tiret)"""
if (EMailAddress.objects
.filter(local_part=login.lower())):
raise forms.ValidationError('Pseudo is already taken')
def get_fresh_user_uid():
""" Renvoie le plus petit uid non pris. Fonction très paresseuse """
@ -195,7 +202,7 @@ class User(RevMixin, FieldPermissionModelMixin, AbstractBaseUser,
max_length=32,
unique=True,
help_text="Doit contenir uniquement des lettres, chiffres, ou tirets",
validators=[linux_user_validator]
validators=[linux_user_validator, pseudo_taken]
)
email = models.EmailField(
blank=True,
@ -1132,8 +1139,7 @@ def user_post_save(**kwargs):
Synchronise le ldap"""
is_created = kwargs['created']
user = kwargs['instance']
EMailAddress.objects.get_or_create(
local_part=user.pseudo.lower(), user=user)
EMailAddress.objects.get_or_create(local_part=user.pseudo.lower(), user=user)
if is_created:
user.notif_inscription()
user.state_sync()
@ -1740,6 +1746,9 @@ class EMailAddress(RevMixin, AclMixin, models.Model):
def __str__(self):
return str(self.local_part) + OptionalUser.get_cached_value('local_email_domain')
def clean(self):
self.local_part = self.local_part.lower()
@cached_property
def complete_email_address(self):
return str(self.local_part) + OptionalUser.get_cached_value('local_email_domain')

Loading…
Cancel
Save