2020-08-23 18:03:18 +03:00
// Copyright 2020 The Gitea Authors. All rights reserved.
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file.
package mailer
import (
"bytes"
"code.gitea.io/gitea/models"
"code.gitea.io/gitea/modules/base"
"code.gitea.io/gitea/modules/log"
2021-04-20 01:25:08 +03:00
"code.gitea.io/gitea/modules/markup"
2020-08-23 18:03:18 +03:00
"code.gitea.io/gitea/modules/markup/markdown"
"code.gitea.io/gitea/modules/setting"
2021-06-23 15:33:21 +03:00
"code.gitea.io/gitea/modules/templates"
2021-04-02 13:25:13 +03:00
"code.gitea.io/gitea/modules/translation"
2020-08-23 18:03:18 +03:00
)
const (
tplNewReleaseMail base . TplName = "release"
)
// MailNewRelease send new release notify to all all repo watchers.
func MailNewRelease ( rel * models . Release ) {
2021-08-12 10:26:33 +03:00
if setting . MailService == nil {
// No mail service configured
return
}
2020-08-23 18:03:18 +03:00
watcherIDList , err := models . GetRepoWatchersIDs ( rel . RepoID )
if err != nil {
log . Error ( "GetRepoWatchersIDs(%d): %v" , rel . RepoID , err )
return
}
2020-09-09 22:08:55 +03:00
recipients , err := models . GetMaileableUsersByIDs ( watcherIDList , false )
2020-08-23 18:03:18 +03:00
if err != nil {
log . Error ( "models.GetMaileableUsersByIDs: %v" , err )
return
}
2021-04-02 13:25:13 +03:00
langMap := make ( map [ string ] [ ] string )
for _ , user := range recipients {
if user . ID != rel . PublisherID {
langMap [ user . Language ] = append ( langMap [ user . Language ] , user . Email )
2020-08-23 18:03:18 +03:00
}
}
2021-04-02 13:25:13 +03:00
for lang , tos := range langMap {
mailNewRelease ( lang , tos , rel )
}
}
func mailNewRelease ( lang string , tos [ ] string , rel * models . Release ) {
locale := translation . NewLocale ( lang )
2021-04-20 01:25:08 +03:00
var err error
rel . RenderedNote , err = markdown . RenderString ( & markup . RenderContext {
URLPrefix : rel . Repo . Link ( ) ,
Metas : rel . Repo . ComposeMetas ( ) ,
} , rel . Note )
if err != nil {
log . Error ( "markdown.RenderString(%d): %v" , rel . RepoID , err )
return
}
2020-08-23 18:03:18 +03:00
2021-04-02 13:25:13 +03:00
subject := locale . Tr ( "mail.release.new.subject" , rel . TagName , rel . Repo . FullName ( ) )
2020-08-23 18:03:18 +03:00
mailMeta := map [ string ] interface { } {
2021-04-02 13:25:13 +03:00
"Release" : rel ,
"Subject" : subject ,
"Language" : locale . Language ( ) ,
2021-06-23 15:33:21 +03:00
// helper
"i18n" : locale ,
"Str2html" : templates . Str2html ,
2021-07-14 16:06:09 +03:00
"TrN" : templates . TrN ,
2020-08-23 18:03:18 +03:00
}
var mailBody bytes . Buffer
2021-04-02 13:25:13 +03:00
if err := bodyTemplates . ExecuteTemplate ( & mailBody , string ( tplNewReleaseMail ) , mailMeta ) ; err != nil {
2020-08-23 18:03:18 +03:00
log . Error ( "ExecuteTemplate [%s]: %v" , string ( tplNewReleaseMail ) + "/body" , err )
return
}
2021-04-02 13:25:13 +03:00
msgs := make ( [ ] * Message , 0 , len ( tos ) )
2020-08-23 18:03:18 +03:00
publisherName := rel . Publisher . DisplayName ( )
relURL := "<" + rel . HTMLURL ( ) + ">"
for _ , to := range tos {
msg := NewMessageFrom ( [ ] string { to } , publisherName , setting . MailService . FromEmail , subject , mailBody . String ( ) )
msg . Info = subject
msg . SetHeader ( "Message-ID" , relURL )
msgs = append ( msgs , msg )
}
SendAsyncs ( msgs )
}