Skip to content

Commit 6068978

Browse files
yardenshohamKN4CK3RGusted
authored
Prevent multiple To recipients (#22566) (#22569)
Backport #22566 Change the mailer interface to prevent the leaking of possible hidden email addresses when sending to multiple recipients. Co-authored-by: KN4CK3R <admin@oldschoolhack.me> Co-authored-by: Gusted <williamzijl7@hotmail.com>
1 parent c320cae commit 6068978

File tree

7 files changed

+23
-20
lines changed

7 files changed

+23
-20
lines changed

Diff for: routers/private/mail.go

+1-1
Original file line numberDiff line numberDiff line change
@@ -81,7 +81,7 @@ func SendEmail(ctx *context.PrivateContext) {
8181

8282
func sendEmail(ctx *context.PrivateContext, subject, message string, to []string) {
8383
for _, email := range to {
84-
msg := mailer.NewMessage([]string{email}, subject, message)
84+
msg := mailer.NewMessage(email, subject, message)
8585
mailer.SendAsync(msg)
8686
}
8787

Diff for: services/mailer/mail.go

+6-6
Original file line numberDiff line numberDiff line change
@@ -61,7 +61,7 @@ func SendTestMail(email string) error {
6161
// No mail service configured
6262
return nil
6363
}
64-
return gomail.Send(Sender, NewMessage([]string{email}, "Gitea Test Email!", "Gitea Test Email!").ToMessage())
64+
return gomail.Send(Sender, NewMessage(email, "Gitea Test Email!", "Gitea Test Email!").ToMessage())
6565
}
6666

6767
// sendUserMail sends a mail to the user
@@ -86,7 +86,7 @@ func sendUserMail(language string, u *user_model.User, tpl base.TplName, code, s
8686
return
8787
}
8888

89-
msg := NewMessage([]string{u.Email}, subject, content.String())
89+
msg := NewMessage(u.Email, subject, content.String())
9090
msg.Info = fmt.Sprintf("UID: %d, %s", u.ID, info)
9191

9292
SendAsync(msg)
@@ -137,7 +137,7 @@ func SendActivateEmailMail(u *user_model.User, email *user_model.EmailAddress) {
137137
return
138138
}
139139

140-
msg := NewMessage([]string{email.Email}, locale.Tr("mail.activate_email"), content.String())
140+
msg := NewMessage(email.Email, locale.Tr("mail.activate_email"), content.String())
141141
msg.Info = fmt.Sprintf("UID: %d, activate email", u.ID)
142142

143143
SendAsync(msg)
@@ -168,7 +168,7 @@ func SendRegisterNotifyMail(u *user_model.User) {
168168
return
169169
}
170170

171-
msg := NewMessage([]string{u.Email}, locale.Tr("mail.register_notify"), content.String())
171+
msg := NewMessage(u.Email, locale.Tr("mail.register_notify"), content.String())
172172
msg.Info = fmt.Sprintf("UID: %d, registration notify", u.ID)
173173

174174
SendAsync(msg)
@@ -202,7 +202,7 @@ func SendCollaboratorMail(u, doer *user_model.User, repo *repo_model.Repository)
202202
return
203203
}
204204

205-
msg := NewMessage([]string{u.Email}, subject, content.String())
205+
msg := NewMessage(u.Email, subject, content.String())
206206
msg.Info = fmt.Sprintf("UID: %d, add collaborator", u.ID)
207207

208208
SendAsync(msg)
@@ -306,7 +306,7 @@ func composeIssueCommentMessages(ctx *mailCommentContext, lang string, recipient
306306

307307
msgs := make([]*Message, 0, len(recipients))
308308
for _, recipient := range recipients {
309-
msg := NewMessageFrom([]string{recipient.Email}, ctx.Doer.DisplayName(), setting.MailService.FromEmail, subject, mailBody.String())
309+
msg := NewMessageFrom(recipient.Email, ctx.Doer.DisplayName(), setting.MailService.FromEmail, subject, mailBody.String())
310310
msg.Info = fmt.Sprintf("Subject: %s, %s", subject, info)
311311

312312
msg.SetHeader("Message-ID", "<"+msgID+">")

Diff for: services/mailer/mail_release.go

+1-1
Original file line numberDiff line numberDiff line change
@@ -90,7 +90,7 @@ func mailNewRelease(ctx context.Context, lang string, tos []string, rel *repo_mo
9090
publisherName := rel.Publisher.DisplayName()
9191
relURL := "<" + rel.HTMLURL() + ">"
9292
for _, to := range tos {
93-
msg := NewMessageFrom([]string{to}, publisherName, setting.MailService.FromEmail, subject, mailBody.String())
93+
msg := NewMessageFrom(to, publisherName, setting.MailService.FromEmail, subject, mailBody.String())
9494
msg.Info = subject
9595
msg.SetHeader("Message-ID", relURL)
9696
msgs = append(msgs, msg)

Diff for: services/mailer/mail_repo.go

+6-3
Original file line numberDiff line numberDiff line change
@@ -83,9 +83,12 @@ func sendRepoTransferNotifyMailPerLang(lang string, newOwner, doer *user_model.U
8383
return err
8484
}
8585

86-
msg := NewMessage(emails, subject, content.String())
87-
msg.Info = fmt.Sprintf("UID: %d, repository pending transfer notification", newOwner.ID)
86+
for _, to := range emails {
87+
msg := NewMessage(to, subject, content.String())
88+
msg.Info = fmt.Sprintf("UID: %d, repository pending transfer notification", newOwner.ID)
89+
90+
SendAsync(msg)
91+
}
8892

89-
SendAsync(msg)
9093
return nil
9194
}

Diff for: services/mailer/mail_team_invite.go

+1-1
Original file line numberDiff line numberDiff line change
@@ -53,7 +53,7 @@ func MailTeamInvite(ctx context.Context, inviter *user_model.User, team *org_mod
5353
return err
5454
}
5555

56-
msg := NewMessage([]string{invite.Email}, subject, mailBody.String())
56+
msg := NewMessage(invite.Email, subject, mailBody.String())
5757
msg.Info = subject
5858

5959
SendAsync(msg)

Diff for: services/mailer/mailer.go

+5-5
Original file line numberDiff line numberDiff line change
@@ -36,7 +36,7 @@ type Message struct {
3636
Info string // Message information for log purpose.
3737
FromAddress string
3838
FromDisplayName string
39-
To []string
39+
To string // Use only one recipient to prevent leaking of addresses
4040
Subject string
4141
Date time.Time
4242
Body string
@@ -47,7 +47,7 @@ type Message struct {
4747
func (m *Message) ToMessage() *gomail.Message {
4848
msg := gomail.NewMessage()
4949
msg.SetAddressHeader("From", m.FromAddress, m.FromDisplayName)
50-
msg.SetHeader("To", m.To...)
50+
msg.SetHeader("To", m.To)
5151
for header := range m.Headers {
5252
msg.SetHeader(header, m.Headers[header]...)
5353
}
@@ -86,15 +86,15 @@ func (m *Message) generateAutoMessageID() string {
8686
dateMs := m.Date.UnixNano() / 1e6
8787
h := fnv.New64()
8888
if len(m.To) > 0 {
89-
_, _ = h.Write([]byte(m.To[0]))
89+
_, _ = h.Write([]byte(m.To))
9090
}
9191
_, _ = h.Write([]byte(m.Subject))
9292
_, _ = h.Write([]byte(m.Body))
9393
return fmt.Sprintf("<autogen-%d-%016x@%s>", dateMs, h.Sum64(), setting.Domain)
9494
}
9595

9696
// NewMessageFrom creates new mail message object with custom From header.
97-
func NewMessageFrom(to []string, fromDisplayName, fromAddress, subject, body string) *Message {
97+
func NewMessageFrom(to, fromDisplayName, fromAddress, subject, body string) *Message {
9898
log.Trace("NewMessageFrom (body):\n%s", body)
9999

100100
return &Message{
@@ -109,7 +109,7 @@ func NewMessageFrom(to []string, fromDisplayName, fromAddress, subject, body str
109109
}
110110

111111
// NewMessage creates new mail message object with default From header.
112-
func NewMessage(to []string, subject, body string) *Message {
112+
func NewMessage(to, subject, body string) *Message {
113113
return NewMessageFrom(to, setting.MailService.FromName, setting.MailService.FromEmail, subject, body)
114114
}
115115

Diff for: services/mailer/mailer_test.go

+3-3
Original file line numberDiff line numberDiff line change
@@ -22,17 +22,17 @@ func TestGenerateMessageID(t *testing.T) {
2222
setting.Domain = "localhost"
2323

2424
date := time.Date(2000, 1, 2, 3, 4, 5, 6, time.UTC)
25-
m := NewMessageFrom(nil, "display-name", "from-address", "subject", "body")
25+
m := NewMessageFrom("", "display-name", "from-address", "subject", "body")
2626
m.Date = date
2727
gm := m.ToMessage()
2828
assert.Equal(t, "<autogen-946782245000-41e8fc54a8ad3a3f@localhost>", gm.GetHeader("Message-ID")[0])
2929

30-
m = NewMessageFrom([]string{"a@b.com"}, "display-name", "from-address", "subject", "body")
30+
m = NewMessageFrom("a@b.com", "display-name", "from-address", "subject", "body")
3131
m.Date = date
3232
gm = m.ToMessage()
3333
assert.Equal(t, "<autogen-946782245000-cc88ce3cfe9bd04f@localhost>", gm.GetHeader("Message-ID")[0])
3434

35-
m = NewMessageFrom([]string{"a@b.com"}, "display-name", "from-address", "subject", "body")
35+
m = NewMessageFrom("a@b.com", "display-name", "from-address", "subject", "body")
3636
m.SetHeader("Message-ID", "<msg-d@domain.com>")
3737
gm = m.ToMessage()
3838
assert.Equal(t, "<msg-d@domain.com>", gm.GetHeader("Message-ID")[0])

0 commit comments

Comments
 (0)