check_uniqueness sur les attributs de type mail corrigée

This commit is contained in:
Pierre-Elliott Bécue 2015-09-10 12:53:55 +02:00
parent c35878562a
commit d20fa54614

View file

@ -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):