check_uniqueness ne se comportait pas mieux qu'avant d20fa54614
This commit is contained in:
parent
c0d2e04cc7
commit
00f67697ee
1 changed files with 24 additions and 18 deletions
18
attributs.py
18
attributs.py
|
@ -756,8 +756,11 @@ class mail(rightProtectedAttr):
|
|||
attr = self.__class__.__name__
|
||||
if str(self) in liste_exclue:
|
||||
return
|
||||
if attr in ["mailAlias", "canonicalAlias", 'mail']:
|
||||
if attr in ["mailAlias", "canonicalAlias", 'mail', 'mailExt']:
|
||||
mail = str(self)
|
||||
|
||||
_, domain = mail.split('@')
|
||||
if domain in config.dns.mail_crans:
|
||||
# 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
|
||||
|
@ -768,11 +771,13 @@ class mail(rightProtectedAttr):
|
|||
res = smtp.getreply()[0] in [250, 252]
|
||||
smtp.close()
|
||||
except:
|
||||
raise ValueError('Serveur de mail injoignable')
|
||||
# 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)
|
||||
print 'Serveur de mail injoignable'
|
||||
|
||||
check = self.conn.search(
|
||||
u'(|(mail=%(mail)s)(mailAlias=%(mail)s)(canonicalAlias=%(mail)s)(mailExt=%(mail)s))' % {
|
||||
'mail': mail,
|
||||
}
|
||||
)
|
||||
if len(check) >= 1:
|
||||
res = True
|
||||
|
||||
|
@ -1614,6 +1619,7 @@ class gpgMail(mail):
|
|||
legend = "Mail associé à une clef gpg"
|
||||
can_modify = [soi, nounou]
|
||||
ldap_name = "gpgMail"
|
||||
|
||||
def check_uniqueness(self, liste_exclue):
|
||||
super(mail, self).check_uniqueness(liste_exclue)
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue