From 83fd11301bbe6f4a34f76b7fcec1c0664034e851 Mon Sep 17 00:00:00 2001 From: Yixin Hao Date: Thu, 20 Aug 2015 13:42:20 +0800 Subject: [PATCH] Added supported of 'AUTH LOGIN' --- modules/mailer/mailer.go | 32 +++++++++++++++++++++++++++++++- 1 file changed, 31 insertions(+), 1 deletion(-) diff --git a/modules/mailer/mailer.go b/modules/mailer/mailer.go index 9dafa93f9..77574851b 100644 --- a/modules/mailer/mailer.go +++ b/modules/mailer/mailer.go @@ -12,11 +12,38 @@ import ( "net/smtp" "os" "strings" - + "errors" "github.com/gogits/gogs/modules/log" "github.com/gogits/gogs/modules/setting" ) +type loginAuth struct { + username, password string +} + +//SMTP AUTH LOGIN Auth Handler +func LoginAuth(username, password string) smtp.Auth { + return &loginAuth{username, password} +} + +func (a *loginAuth) Start(server *smtp.ServerInfo) (string, []byte, error) { + return "LOGIN", []byte{}, nil +} + +func (a *loginAuth) Next(fromServer []byte, more bool) ([]byte, error) { + if more { + switch string(fromServer) { + case "Username:": + return []byte(a.username), nil + case "Password:": + return []byte(a.password), nil + default: + return nil, errors.New("Unkown fromServer") + } + } + return nil, nil +} + type Message struct { To []string From string @@ -135,6 +162,9 @@ func sendMail(settings *setting.Mailer, recipients []string, msgContent []byte) auth = smtp.CRAMMD5Auth(settings.User, settings.Passwd) } else if strings.Contains(options, "PLAIN") { auth = smtp.PlainAuth("", settings.User, settings.Passwd, host) + //Patch for AUTH LOGIN + } else if strings.Contains(options, "LOGIN") { + auth = LoginAuth(settings.Use, settings.Passwd) } if auth != nil {