Merge pull request #762 from phsmit/crammd5

Crammd5
This commit is contained in:
无闻 2014-12-18 16:49:11 -05:00
commit d01e7b0173

View file

@ -108,14 +108,21 @@ func sendMail(settings *setting.Mailer, from string, recipients []string, msgCon
}
}
auth_available, _ := client.Extension("AUTH")
auth_available, options := client.Extension("AUTH")
// Possible improvement: only plain authentication is now available.
// Maybe in future CRAM MD5 as well?
if auth_available && len(settings.User) > 0 {
auth := smtp.PlainAuth("", settings.User, settings.Passwd, host)
if err = client.Auth(auth); err != nil {
return err
var auth smtp.Auth
if strings.Contains(options, "CRAM-MD5") {
auth = smtp.CRAMMD5Auth(settings.User, settings.Passwd)
} else if strings.Contains(options, "PLAIN") {
auth = smtp.PlainAuth("", settings.User, settings.Passwd, host)
}
if auth != nil {
if err = client.Auth(auth); err != nil {
return err
}
}
}