Merge pull request #762 from phsmit/crammd5

Crammd5
pull/197/head
无闻 10 years ago
commit d01e7b0173
  1. 19
      modules/mailer/mailer.go

@ -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 { if auth_available && len(settings.User) > 0 {
auth := smtp.PlainAuth("", settings.User, settings.Passwd, host) var auth smtp.Auth
if err = client.Auth(auth); err != nil {
return err 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
}
} }
} }

Loading…
Cancel
Save