aboutsummaryrefslogtreecommitdiffstats
path: root/modules
diff options
context:
space:
mode:
authorUnknwon <u@gogs.io>2016-07-16 00:36:39 +0800
committerUnknwon <u@gogs.io>2016-07-16 00:36:39 +0800
commitf1b8d52eb3ac230ed5a275f4a844ddb0cf48041e (patch)
tree51dda05a9fb7a985a4e91f3e1708ffddf3fee19c /modules
parent7ca5f8f119593023809e6130db75154597c52426 (diff)
downloadgitea-f1b8d52eb3ac230ed5a275f4a844ddb0cf48041e.tar.gz
gitea-f1b8d52eb3ac230ed5a275f4a844ddb0cf48041e.zip
#2854 fix no mail notification when issue is closed/reopened
Diffstat (limited to 'modules')
-rw-r--r--modules/mailer/mail.go190
-rw-r--r--modules/mailer/mailer.go4
-rw-r--r--modules/markdown/markdown.go13
3 files changed, 16 insertions, 191 deletions
diff --git a/modules/mailer/mail.go b/modules/mailer/mail.go
deleted file mode 100644
index 440ffdc01f..0000000000
--- a/modules/mailer/mail.go
+++ /dev/null
@@ -1,190 +0,0 @@
-// Copyright 2014 The Gogs 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 (
- "fmt"
- "path"
- "strings"
-
- "gopkg.in/gomail.v2"
- "gopkg.in/macaron.v1"
-
- "github.com/gogits/gogs/models"
- "github.com/gogits/gogs/modules/base"
- "github.com/gogits/gogs/modules/log"
- "github.com/gogits/gogs/modules/markdown"
- "github.com/gogits/gogs/modules/setting"
-)
-
-const (
- AUTH_ACTIVATE base.TplName = "mail/auth/activate"
- AUTH_ACTIVATE_EMAIL base.TplName = "mail/auth/activate_email"
- AUTH_REGISTER_NOTIFY base.TplName = "mail/auth/register_notify"
- AUTH_RESET_PASSWORD base.TplName = "mail/auth/reset_passwd"
-
- NOTIFY_COLLABORATOR base.TplName = "mail/notify/collaborator"
- NOTIFY_MENTION base.TplName = "mail/notify/mention"
-)
-
-func ComposeTplData(u *models.User) map[interface{}]interface{} {
- data := make(map[interface{}]interface{}, 10)
- data["AppName"] = setting.AppName
- data["AppVer"] = setting.AppVer
- data["AppUrl"] = setting.AppUrl
- data["ActiveCodeLives"] = setting.Service.ActiveCodeLives / 60
- data["ResetPwdCodeLives"] = setting.Service.ResetPwdCodeLives / 60
-
- if u != nil {
- data["User"] = u
- }
- return data
-}
-
-func SendUserMail(c *macaron.Context, u *models.User, tpl base.TplName, code, subject, info string) {
- data := ComposeTplData(u)
- data["Code"] = code
- body, err := c.HTMLString(string(tpl), data)
- if err != nil {
- log.Error(4, "HTMLString: %v", err)
- return
- }
-
- msg := NewMessage([]string{u.Email}, subject, body)
- msg.Info = fmt.Sprintf("UID: %d, %s", u.Id, info)
-
- SendAsync(msg)
-}
-
-func SendActivateAccountMail(c *macaron.Context, u *models.User) {
- SendUserMail(c, u, AUTH_ACTIVATE, u.GenerateActivateCode(), c.Tr("mail.activate_account"), "activate account")
-}
-
-// SendResetPasswordMail sends reset password e-mail.
-func SendResetPasswordMail(c *macaron.Context, u *models.User) {
- SendUserMail(c, u, AUTH_RESET_PASSWORD, u.GenerateActivateCode(), c.Tr("mail.reset_password"), "reset password")
-}
-
-// SendRegisterNotifyMail triggers a notify e-mail by admin created a account.
-func SendRegisterNotifyMail(c *macaron.Context, u *models.User) {
- body, err := c.HTMLString(string(AUTH_REGISTER_NOTIFY), ComposeTplData(u))
- if err != nil {
- log.Error(4, "HTMLString: %v", err)
- return
- }
-
- msg := NewMessage([]string{u.Email}, c.Tr("mail.register_notify"), body)
- msg.Info = fmt.Sprintf("UID: %d, registration notify", u.Id)
-
- SendAsync(msg)
-}
-
-// SendActivateAccountMail sends confirmation e-mail.
-func SendActivateEmailMail(c *macaron.Context, u *models.User, email *models.EmailAddress) {
- data := ComposeTplData(u)
- data["Code"] = u.GenerateEmailActivateCode(email.Email)
- data["Email"] = email.Email
- body, err := c.HTMLString(string(AUTH_ACTIVATE_EMAIL), data)
- if err != nil {
- log.Error(4, "HTMLString: %v", err)
- return
- }
-
- msg := NewMessage([]string{email.Email}, c.Tr("mail.activate_email"), body)
- msg.Info = fmt.Sprintf("UID: %d, activate email", u.Id)
-
- SendAsync(msg)
-}
-
-// SendIssueNotifyMail sends mail notification of all watchers of repository.
-func SendIssueNotifyMail(u, owner *models.User, repo *models.Repository, issue *models.Issue) ([]string, error) {
- ws, err := models.GetWatchers(repo.ID)
- if err != nil {
- return nil, fmt.Errorf("GetWatchers[%d]: %v", repo.ID, err)
- }
-
- tos := make([]string, 0, len(ws))
- for i := range ws {
- uid := ws[i].UserID
- if u.Id == uid {
- continue
- }
- to, err := models.GetUserByID(uid)
- if err != nil {
- return nil, fmt.Errorf("GetUserByID: %v", err)
- }
- if to.IsOrganization() {
- continue
- }
-
- tos = append(tos, to.Email)
- }
-
- if len(tos) == 0 {
- return tos, nil
- }
-
- subject := fmt.Sprintf("[%s] %s (#%d)", repo.Name, issue.Name, issue.Index)
- content := fmt.Sprintf("%s<br>-<br> <a href=\"%s%s/%s/issues/%d\">View it on Gogs</a>.",
- markdown.RenderSpecialLink([]byte(strings.Replace(issue.Content, "\n", "<br>", -1)), owner.Name+"/"+repo.Name, repo.ComposeMetas()),
- setting.AppUrl, owner.Name, repo.Name, issue.Index)
- msg := NewMessage(tos, subject, content)
- msg.Info = fmt.Sprintf("Subject: %s, issue notify", subject)
-
- SendAsync(msg)
- return tos, nil
-}
-
-// SendIssueMentionMail sends mail notification for who are mentioned in issue.
-func SendIssueMentionMail(r macaron.Render, u, owner *models.User,
- repo *models.Repository, issue *models.Issue, tos []string) error {
-
- if len(tos) == 0 {
- return nil
- }
-
- subject := fmt.Sprintf("[%s] %s (#%d)", repo.Name, issue.Name, issue.Index)
-
- data := ComposeTplData(nil)
- data["IssueLink"] = fmt.Sprintf("%s/%s/issues/%d", owner.Name, repo.Name, issue.Index)
- data["Subject"] = subject
- data["ActUserName"] = u.DisplayName()
- data["Content"] = string(markdown.RenderSpecialLink([]byte(issue.Content), owner.Name+"/"+repo.Name, repo.ComposeMetas()))
-
- body, err := r.HTMLString(string(NOTIFY_MENTION), data)
- if err != nil {
- return fmt.Errorf("HTMLString: %v", err)
- }
-
- msg := NewMessage(tos, subject, body)
- msg.Info = fmt.Sprintf("Subject: %s, issue mention", subject)
-
- SendAsync(msg)
- return nil
-}
-
-// SendCollaboratorMail sends mail notification to new collaborator.
-func SendCollaboratorMail(r macaron.Render, u, doer *models.User, repo *models.Repository) error {
- subject := fmt.Sprintf("%s added you to %s/%s", doer.Name, repo.Owner.Name, repo.Name)
-
- data := ComposeTplData(nil)
- data["RepoLink"] = path.Join(repo.Owner.Name, repo.Name)
- data["Subject"] = subject
-
- body, err := r.HTMLString(string(NOTIFY_COLLABORATOR), data)
- if err != nil {
- return fmt.Errorf("HTMLString: %v", err)
- }
-
- msg := NewMessage([]string{u.Email}, subject, body)
- msg.Info = fmt.Sprintf("UID: %d, add collaborator", u.Id)
-
- SendAsync(msg)
- return nil
-}
-
-func SendTestMail(email string) error {
- return gomail.Send(&Sender{}, NewMessage([]string{email}, "Gogs Test Email!", "Gogs Test Email!").Message)
-}
diff --git a/modules/mailer/mailer.go b/modules/mailer/mailer.go
index 13d80b5648..80a692699e 100644
--- a/modules/mailer/mailer.go
+++ b/modules/mailer/mailer.go
@@ -28,6 +28,8 @@ type Message struct {
// NewMessageFrom creates new mail message object with custom From header.
func NewMessageFrom(to []string, from, subject, htmlBody string) *Message {
+ log.Trace("NewMessageFrom (htmlBody):\n%s", htmlBody)
+
msg := gomail.NewMessage()
msg.SetHeader("From", from)
msg.SetHeader("To", to...)
@@ -196,7 +198,7 @@ func processMailQueue() {
case msg := <-mailQueue:
log.Trace("New e-mail sending request %s: %s", msg.GetHeader("To"), msg.Info)
if err := gomail.Send(sender, msg.Message); err != nil {
- log.Error(4, "Fail to send e-mails %s: %s - %v", msg.GetHeader("To"), msg.Info, err)
+ log.Error(3, "Fail to send emails %s: %s - %v", msg.GetHeader("To"), msg.Info, err)
} else {
log.Trace("E-mails sent %s: %s", msg.GetHeader("To"), msg.Info)
}
diff --git a/modules/markdown/markdown.go b/modules/markdown/markdown.go
index 99a4323d99..d49c14d1f9 100644
--- a/modules/markdown/markdown.go
+++ b/modules/markdown/markdown.go
@@ -93,6 +93,16 @@ var (
Sha1CurrentPattern = regexp.MustCompile(`\b[0-9a-f]{40}\b`)
)
+// FindAllMentions matches mention patterns in given content
+// and returns a list of found user names without @ prefix.
+func FindAllMentions(content string) []string {
+ mentions := MentionPattern.FindAllString(content, -1)
+ for i := range mentions {
+ mentions[i] = strings.TrimSpace(mentions[i])[1:] // Strip @ character
+ }
+ return mentions
+}
+
// Renderer is a extended version of underlying render object.
type Renderer struct {
blackfriday.Renderer
@@ -202,6 +212,9 @@ func (r *Renderer) Image(out *bytes.Buffer, link []byte, title []byte, alt []byt
// cutoutVerbosePrefix cutouts URL prefix including sub-path to
// return a clean unified string of request URL path.
func cutoutVerbosePrefix(prefix string) string {
+ if len(prefix) == 0 || prefix[0] != '/' {
+ return prefix
+ }
count := 0
for i := 0; i < len(prefix); i++ {
if prefix[i] == '/' {