Skip to content

Commit

Permalink
[PLT-1015] Make all Mattermost system emails Multi-Part, with both a …
Browse files Browse the repository at this point in the history
…HTML and Plain Text version. (mattermost#5698)

* Implementation to Make all Mattermost system emails Multi-Part, with both a HTML and Plain Text version

* update lib

* update code per review

* update to use the mattermost repo
  • Loading branch information
cpanato authored and crspeller committed Aug 21, 2017
1 parent 65ccd4a commit 12a9180
Show file tree
Hide file tree
Showing 5 changed files with 30 additions and 26 deletions.
2 changes: 1 addition & 1 deletion NOTICE.txt
Original file line number Diff line number Diff line change
Expand Up @@ -4655,7 +4655,7 @@ MIT license
This product contains a modified portion of 'html2text', an HTML to raw text converter by Carlos Tadeu Panato Junior, based on `html2text` by Jay Taylor.

* HOMEPAGE
* https://github.com/cpanato/html2text
* https://github.com/mattermost/html2text

* LICENSE

Expand Down
1 change: 0 additions & 1 deletion app/admin.go
Original file line number Diff line number Diff line change
Expand Up @@ -212,7 +212,6 @@ func TestEmail(userId string, cfg *model.Config) *model.AppError {
return model.NewLocAppError("testEmail", "api.admin.test_email.reenter_password", nil, "")
}
}

if user, err := GetUser(userId); err != nil {
return err
} else {
Expand Down
2 changes: 1 addition & 1 deletion app/email_batching.go
Original file line number Diff line number Diff line change
Expand Up @@ -218,7 +218,7 @@ func sendBatchedEmailNotification(userId string, notifications []*batchedNotific
body.Props["BodyText"] = translateFunc("api.email_batching.send_batched_email_notification.body_text", len(notifications))

if err := utils.SendMail(user.Email, subject, body.Render()); err != nil {
l4g.Warn(utils.T("api.email_batching.send_batched_email_notification.send.app_error"), user.Email, err)
l4g.Warn(utils.T("api.email_batchings.send_batched_email_notification.send.app_error"), user.Email, err)
}
}

Expand Down
4 changes: 2 additions & 2 deletions app/email_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ func TestSendEmailChangeVerifyEmail(t *testing.T) {

var newUserEmail string = "[email protected]"
var locale string = "en"
var siteURL string = ""
var siteURL string = "http://localhost:8065"
var expectedPartialMessage string = "You updated your email"
var expectedSubject string = "[" + utils.Cfg.TeamSettings.SiteName + "] Verify new email address"
var token string = "TEST_TOKEN"
Expand Down Expand Up @@ -174,7 +174,7 @@ func TestSendVerifyEmail(t *testing.T) {

var userEmail string = "[email protected]"
var locale string = "en"
var siteURL string = ""
var siteURL string = "http://localhost:8605"
var expectedPartialMessage string = "Please verify your email address by clicking below"
var expectedSubject string = "[" + utils.Cfg.TeamSettings.SiteName + "] Email Verification"
var token string = "TEST_TOKEN"
Expand Down
47 changes: 26 additions & 21 deletions utils/mail.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,14 +5,16 @@ package utils

import (
"crypto/tls"
"fmt"
"mime"
"net"
"net/mail"
"net/smtp"
"time"

"gopkg.in/gomail.v2"

l4g "github.com/alecthomas/log4go"
"github.com/mattermost/html2text"
"github.com/mattermost/platform/model"
)

Expand Down Expand Up @@ -99,34 +101,38 @@ func TestConnection(config *model.Config) {
defer c.Close()
}

func SendMail(to, subject, body string) *model.AppError {
return SendMailUsingConfig(to, subject, body, Cfg)
func SendMail(to, subject, htmlBody string) *model.AppError {
return SendMailUsingConfig(to, subject, htmlBody, Cfg)
}

func SendMailUsingConfig(to, subject, body string, config *model.Config) *model.AppError {
func SendMailUsingConfig(to, subject, htmlBody string, config *model.Config) *model.AppError {
if !config.EmailSettings.SendEmailNotifications || len(config.EmailSettings.SMTPServer) == 0 {
return nil
}

l4g.Debug(T("utils.mail.send_mail.sending.debug"), to, subject)

fromMail := mail.Address{Name: config.EmailSettings.FeedbackName, Address: config.EmailSettings.FeedbackEmail}
toMail := mail.Address{Name: "", Address: to}
htmlMessage := "\r\n<html><body>" + htmlBody + "</body></html>"

headers := make(map[string]string)
headers["From"] = fromMail.String()
headers["To"] = toMail.String()
headers["Subject"] = encodeRFC2047Word(subject)
headers["MIME-version"] = "1.0"
headers["Content-Type"] = "text/html; charset=\"utf-8\""
headers["Content-Transfer-Encoding"] = "8bit"
headers["Date"] = time.Now().Format(time.RFC1123Z)
fromMail := mail.Address{Name: config.EmailSettings.FeedbackName, Address: config.EmailSettings.FeedbackEmail}

message := ""
for k, v := range headers {
message += fmt.Sprintf("%s: %s\r\n", k, v)
txtBody, err := html2text.FromString(htmlBody)
if err != nil {
l4g.Warn(err)
txtBody = ""
}
message += "\r\n<html><body>" + body + "</body></html>"

m := gomail.NewMessage(gomail.SetCharset("UTF-8"))
m.SetHeaders(map[string][]string{
"From": {fromMail.String()},
"To": {to},
"Subject": {encodeRFC2047Word(subject)},
"Content-Transfer-Encoding": {"8bit"},
})
m.SetDateHeader("Date", time.Now())

m.SetBody("text/plain", txtBody)
m.AddAlternative("text/html", htmlMessage)

conn, err1 := connectToSMTPServer(config)
if err1 != nil {
Expand All @@ -145,7 +151,7 @@ func SendMailUsingConfig(to, subject, body string, config *model.Config) *model.
return model.NewLocAppError("SendMail", "utils.mail.send_mail.from_address.app_error", nil, err.Error())
}

if err := c.Rcpt(toMail.Address); err != nil {
if err := c.Rcpt(to); err != nil {
return model.NewLocAppError("SendMail", "utils.mail.send_mail.to_address.app_error", nil, err.Error())
}

Expand All @@ -154,11 +160,10 @@ func SendMailUsingConfig(to, subject, body string, config *model.Config) *model.
return model.NewLocAppError("SendMail", "utils.mail.send_mail.msg_data.app_error", nil, err.Error())
}

_, err = w.Write([]byte(message))
_, err = m.WriteTo(w)
if err != nil {
return model.NewLocAppError("SendMail", "utils.mail.send_mail.msg.app_error", nil, err.Error())
}

err = w.Close()
if err != nil {
return model.NewLocAppError("SendMail", "utils.mail.send_mail.close.app_error", nil, err.Error())
Expand Down

0 comments on commit 12a9180

Please sign in to comment.