check_uniqueness sur les attributs de type mail corrigée
This commit is contained in:
parent
c35878562a
commit
d20fa54614
1 changed files with 19 additions and 14 deletions
17
attributs.py
17
attributs.py
|
@ -743,8 +743,11 @@ class mail(rightProtectedAttr):
|
|||
if str(self) in liste_exclue:
|
||||
return
|
||||
if attr in ["mailAlias", "canonicalAlias", 'mail']:
|
||||
mail, end = str(self).split('@', 1)
|
||||
if end.startswith('crans'):
|
||||
mail = str(self)
|
||||
# On commence par vérifier auprès du serveur SMTP
|
||||
# si l'adresse email est prise sur le réseau. Cela permet
|
||||
# de tester aussi les adresses statiquement écrites dans
|
||||
# aliases.db.
|
||||
try:
|
||||
smtp = smtplib.SMTP(smtpserv)
|
||||
smtp.putcmd("vrfy", mail)
|
||||
|
@ -752,12 +755,14 @@ class mail(rightProtectedAttr):
|
|||
smtp.close()
|
||||
except:
|
||||
raise ValueError('Serveur de mail injoignable')
|
||||
|
||||
if res:
|
||||
raise ValueError("Le mail %s est déjà pris." % (str(self)))
|
||||
else:
|
||||
# Si le SMTP n'est pas joignable, on joue à la roulette
|
||||
# russe en demandant à LDAP, sans vérifier les aliases
|
||||
# statiques…
|
||||
check = self.conn.search(u'mail=%s' % mail)
|
||||
if len(check) >= 1:
|
||||
res = True
|
||||
|
||||
if res:
|
||||
raise ValueError("Le mail %s est déjà pris." % (str(self)))
|
||||
|
||||
def parse_value(self, mail):
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue