* mail notification implement interface * fix file comment year * use NullNotifier as parent struct of notifierstags/v1.21.12.1
@@ -1121,9 +1121,6 @@ func NewIssue(repo *Repository, issue *Issue, labelIDs []int64, assigneeIDs []in | |||||
}); err != nil { | }); err != nil { | ||||
log.Error(4, "NotifyWatchers: %v", err) | log.Error(4, "NotifyWatchers: %v", err) | ||||
} | } | ||||
if err = issue.MailParticipants(); err != nil { | |||||
log.Error(4, "MailParticipants: %v", err) | |||||
} | |||||
mode, _ := AccessLevel(issue.Poster, issue.Repo) | mode, _ := AccessLevel(issue.Poster, issue.Repo) | ||||
if err = PrepareWebhooks(repo, HookEventIssues, &api.IssuePayload{ | if err = PrepareWebhooks(repo, HookEventIssues, &api.IssuePayload{ | ||||
@@ -361,7 +361,11 @@ func (c *Comment) LoadDepIssueDetails() (err error) { | |||||
// MailParticipants sends new comment emails to repository watchers | // MailParticipants sends new comment emails to repository watchers | ||||
// and mentioned people. | // and mentioned people. | ||||
func (c *Comment) MailParticipants(e Engine, opType ActionType, issue *Issue) (err error) { | |||||
func (c *Comment) MailParticipants(opType ActionType, issue *Issue) (err error) { | |||||
return c.mailParticipants(x, opType, issue) | |||||
} | |||||
func (c *Comment) mailParticipants(e Engine, opType ActionType, issue *Issue) (err error) { | |||||
mentions := markup.FindAllMentions(c.Content) | mentions := markup.FindAllMentions(c.Content) | ||||
if err = UpdateIssueMentions(e, c.IssueID, mentions); err != nil { | if err = UpdateIssueMentions(e, c.IssueID, mentions); err != nil { | ||||
return fmt.Errorf("UpdateIssueMentions [%d]: %v", c.IssueID, err) | return fmt.Errorf("UpdateIssueMentions [%d]: %v", c.IssueID, err) | ||||
@@ -632,9 +636,6 @@ func sendCreateCommentAction(e *xorm.Session, opts *CreateCommentOptions, commen | |||||
if err = notifyWatchers(e, act); err != nil { | if err = notifyWatchers(e, act); err != nil { | ||||
log.Error(4, "notifyWatchers: %v", err) | log.Error(4, "notifyWatchers: %v", err) | ||||
} | } | ||||
if err = comment.MailParticipants(e, act.OpType, opts.Issue); err != nil { | |||||
log.Error(4, "MailParticipants: %v", err) | |||||
} | |||||
} | } | ||||
return nil | return nil | ||||
} | } | ||||
@@ -845,8 +845,6 @@ func NewPullRequest(repo *Repository, pull *Issue, labelIDs []int64, uuids []str | |||||
IsPrivate: repo.IsPrivate, | IsPrivate: repo.IsPrivate, | ||||
}); err != nil { | }); err != nil { | ||||
log.Error(4, "NotifyWatchers: %v", err) | log.Error(4, "NotifyWatchers: %v", err) | ||||
} else if err = pull.MailParticipants(); err != nil { | |||||
log.Error(4, "MailParticipants: %v", err) | |||||
} | } | ||||
pr.Issue = pull | pr.Issue = pull | ||||
@@ -0,0 +1,108 @@ | |||||
// Copyright 2019 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 base | |||||
import ( | |||||
"code.gitea.io/git" | |||||
"code.gitea.io/gitea/models" | |||||
) | |||||
// NullNotifier implements a blank notifier | |||||
type NullNotifier struct { | |||||
} | |||||
var ( | |||||
_ Notifier = &NullNotifier{} | |||||
) | |||||
// Run places a place holder function | |||||
func (*NullNotifier) Run() { | |||||
} | |||||
// NotifyCreateIssueComment places a place holder function | |||||
func (*NullNotifier) NotifyCreateIssueComment(doer *models.User, repo *models.Repository, | |||||
issue *models.Issue, comment *models.Comment) { | |||||
} | |||||
// NotifyNewIssue places a place holder function | |||||
func (*NullNotifier) NotifyNewIssue(issue *models.Issue) { | |||||
} | |||||
// NotifyIssueChangeStatus places a place holder function | |||||
func (*NullNotifier) NotifyIssueChangeStatus(doer *models.User, issue *models.Issue, isClosed bool) { | |||||
} | |||||
// NotifyNewPullRequest places a place holder function | |||||
func (*NullNotifier) NotifyNewPullRequest(pr *models.PullRequest) { | |||||
} | |||||
// NotifyPullRequestReview places a place holder function | |||||
func (*NullNotifier) NotifyPullRequestReview(pr *models.PullRequest, r *models.Review, comment *models.Comment) { | |||||
} | |||||
// NotifyMergePullRequest places a place holder function | |||||
func (*NullNotifier) NotifyMergePullRequest(pr *models.PullRequest, doer *models.User, baseRepo *git.Repository) { | |||||
} | |||||
// NotifyUpdateComment places a place holder function | |||||
func (*NullNotifier) NotifyUpdateComment(doer *models.User, c *models.Comment, oldContent string) { | |||||
} | |||||
// NotifyDeleteComment places a place holder function | |||||
func (*NullNotifier) NotifyDeleteComment(doer *models.User, c *models.Comment) { | |||||
} | |||||
// NotifyDeleteRepository places a place holder function | |||||
func (*NullNotifier) NotifyDeleteRepository(doer *models.User, repo *models.Repository) { | |||||
} | |||||
// NotifyForkRepository places a place holder function | |||||
func (*NullNotifier) NotifyForkRepository(doer *models.User, oldRepo, repo *models.Repository) { | |||||
} | |||||
// NotifyNewRelease places a place holder function | |||||
func (*NullNotifier) NotifyNewRelease(rel *models.Release) { | |||||
} | |||||
// NotifyUpdateRelease places a place holder function | |||||
func (*NullNotifier) NotifyUpdateRelease(doer *models.User, rel *models.Release) { | |||||
} | |||||
// NotifyDeleteRelease places a place holder function | |||||
func (*NullNotifier) NotifyDeleteRelease(doer *models.User, rel *models.Release) { | |||||
} | |||||
// NotifyIssueChangeMilestone places a place holder function | |||||
func (*NullNotifier) NotifyIssueChangeMilestone(doer *models.User, issue *models.Issue) { | |||||
} | |||||
// NotifyIssueChangeContent places a place holder function | |||||
func (*NullNotifier) NotifyIssueChangeContent(doer *models.User, issue *models.Issue, oldContent string) { | |||||
} | |||||
// NotifyIssueChangeAssignee places a place holder function | |||||
func (*NullNotifier) NotifyIssueChangeAssignee(doer *models.User, issue *models.Issue, removed bool) { | |||||
} | |||||
// NotifyIssueClearLabels places a place holder function | |||||
func (*NullNotifier) NotifyIssueClearLabels(doer *models.User, issue *models.Issue) { | |||||
} | |||||
// NotifyIssueChangeTitle places a place holder function | |||||
func (*NullNotifier) NotifyIssueChangeTitle(doer *models.User, issue *models.Issue, oldTitle string) { | |||||
} | |||||
// NotifyIssueChangeLabels places a place holder function | |||||
func (*NullNotifier) NotifyIssueChangeLabels(doer *models.User, issue *models.Issue, | |||||
addedLabels []*models.Label, removedLabels []*models.Label) { | |||||
} | |||||
// NotifyCreateRepository places a place holder function | |||||
func (*NullNotifier) NotifyCreateRepository(doer *models.User, u *models.User, repo *models.Repository) { | |||||
} | |||||
// NotifyMigrateRepository places a place holder function | |||||
func (*NullNotifier) NotifyMigrateRepository(doer *models.User, u *models.User, repo *models.Repository) { | |||||
} |
@@ -0,0 +1,74 @@ | |||||
// Copyright 2019 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 mail | |||||
import ( | |||||
"code.gitea.io/gitea/models" | |||||
"code.gitea.io/gitea/modules/log" | |||||
"code.gitea.io/gitea/modules/notification/base" | |||||
) | |||||
type mailNotifier struct { | |||||
base.NullNotifier | |||||
} | |||||
var ( | |||||
_ base.Notifier = &mailNotifier{} | |||||
) | |||||
// NewNotifier create a new mailNotifier notifier | |||||
func NewNotifier() base.Notifier { | |||||
return &mailNotifier{} | |||||
} | |||||
func (m *mailNotifier) NotifyCreateIssueComment(doer *models.User, repo *models.Repository, | |||||
issue *models.Issue, comment *models.Comment) { | |||||
var act models.ActionType | |||||
if comment.Type == models.CommentTypeClose { | |||||
act = models.ActionCloseIssue | |||||
} else if comment.Type == models.CommentTypeReopen { | |||||
act = models.ActionReopenIssue | |||||
} else if comment.Type == models.CommentTypeComment { | |||||
act = models.ActionCommentIssue | |||||
} else if comment.Type == models.CommentTypeCode { | |||||
act = models.ActionCommentIssue | |||||
} | |||||
if err := comment.MailParticipants(act, issue); err != nil { | |||||
log.Error(4, "MailParticipants: %v", err) | |||||
} | |||||
} | |||||
func (m *mailNotifier) NotifyNewIssue(issue *models.Issue) { | |||||
if err := issue.MailParticipants(); err != nil { | |||||
log.Error(4, "MailParticipants: %v", err) | |||||
} | |||||
} | |||||
func (m *mailNotifier) NotifyIssueChangeStatus(doer *models.User, issue *models.Issue, isClosed bool) { | |||||
if err := issue.MailParticipants(); err != nil { | |||||
log.Error(4, "MailParticipants: %v", err) | |||||
} | |||||
} | |||||
func (m *mailNotifier) NotifyNewPullRequest(pr *models.PullRequest) { | |||||
if err := pr.Issue.MailParticipants(); err != nil { | |||||
log.Error(4, "MailParticipants: %v", err) | |||||
} | |||||
} | |||||
func (m *mailNotifier) NotifyPullRequestReview(pr *models.PullRequest, r *models.Review, comment *models.Comment) { | |||||
var act models.ActionType | |||||
if comment.Type == models.CommentTypeClose { | |||||
act = models.ActionCloseIssue | |||||
} else if comment.Type == models.CommentTypeReopen { | |||||
act = models.ActionReopenIssue | |||||
} else if comment.Type == models.CommentTypeComment { | |||||
act = models.ActionCommentIssue | |||||
} | |||||
if err := comment.MailParticipants(act, pr.Issue); err != nil { | |||||
log.Error(4, "MailParticipants: %v", err) | |||||
} | |||||
} |
@@ -8,6 +8,7 @@ import ( | |||||
"code.gitea.io/git" | "code.gitea.io/git" | ||||
"code.gitea.io/gitea/models" | "code.gitea.io/gitea/models" | ||||
"code.gitea.io/gitea/modules/notification/base" | "code.gitea.io/gitea/modules/notification/base" | ||||
"code.gitea.io/gitea/modules/notification/mail" | |||||
"code.gitea.io/gitea/modules/notification/ui" | "code.gitea.io/gitea/modules/notification/ui" | ||||
) | ) | ||||
@@ -23,6 +24,7 @@ func RegisterNotifier(notifier base.Notifier) { | |||||
func init() { | func init() { | ||||
RegisterNotifier(ui.NewNotifier()) | RegisterNotifier(ui.NewNotifier()) | ||||
RegisterNotifier(mail.NewNotifier()) | |||||
} | } | ||||
// NotifyCreateIssueComment notifies issue comment related message to notifiers | // NotifyCreateIssueComment notifies issue comment related message to notifiers | ||||
@@ -13,6 +13,7 @@ import ( | |||||
type ( | type ( | ||||
notificationService struct { | notificationService struct { | ||||
base.NullNotifier | |||||
issueQueue chan issueNotificationOpts | issueQueue chan issueNotificationOpts | ||||
} | } | ||||
@@ -86,49 +87,3 @@ func (ns *notificationService) NotifyPullRequestReview(pr *models.PullRequest, r | |||||
r.Reviewer.ID, | r.Reviewer.ID, | ||||
} | } | ||||
} | } | ||||
func (ns *notificationService) NotifyUpdateComment(doer *models.User, c *models.Comment, oldContent string) { | |||||
} | |||||
func (ns *notificationService) NotifyDeleteComment(doer *models.User, c *models.Comment) { | |||||
} | |||||
func (ns *notificationService) NotifyDeleteRepository(doer *models.User, repo *models.Repository) { | |||||
} | |||||
func (ns *notificationService) NotifyForkRepository(doer *models.User, oldRepo, repo *models.Repository) { | |||||
} | |||||
func (ns *notificationService) NotifyNewRelease(rel *models.Release) { | |||||
} | |||||
func (ns *notificationService) NotifyUpdateRelease(doer *models.User, rel *models.Release) { | |||||
} | |||||
func (ns *notificationService) NotifyDeleteRelease(doer *models.User, rel *models.Release) { | |||||
} | |||||
func (ns *notificationService) NotifyIssueChangeMilestone(doer *models.User, issue *models.Issue) { | |||||
} | |||||
func (ns *notificationService) NotifyIssueChangeContent(doer *models.User, issue *models.Issue, oldContent string) { | |||||
} | |||||
func (ns *notificationService) NotifyIssueChangeAssignee(doer *models.User, issue *models.Issue, removed bool) { | |||||
} | |||||
func (ns *notificationService) NotifyIssueClearLabels(doer *models.User, issue *models.Issue) { | |||||
} | |||||
func (ns *notificationService) NotifyIssueChangeTitle(doer *models.User, issue *models.Issue, oldTitle string) { | |||||
} | |||||
func (ns *notificationService) NotifyIssueChangeLabels(doer *models.User, issue *models.Issue, | |||||
addedLabels []*models.Label, removedLabels []*models.Label) { | |||||
} | |||||
func (ns *notificationService) NotifyCreateRepository(doer *models.User, u *models.User, repo *models.Repository) { | |||||
} | |||||
func (ns *notificationService) NotifyMigrateRepository(doer *models.User, u *models.User, repo *models.Repository) { | |||||
} |