summaryrefslogtreecommitdiffstats
path: root/models/notification.go
diff options
context:
space:
mode:
author6543 <6543@obermui.de>2020-02-26 07:32:22 +0100
committerGitHub <noreply@github.com>2020-02-26 07:32:22 +0100
commit084a2b00268ed561f59ac19b1b6660a3c58573b3 (patch)
tree5474cb8c1bd5a16251edf46cd99d54757e3ebc0c /models/notification.go
parentChange admin dashboard to POST (#10465) (diff)
downloadforgejo-084a2b00268ed561f59ac19b1b6660a3c58573b3.tar.xz
forgejo-084a2b00268ed561f59ac19b1b6660a3c58573b3.zip
Code Refactor of IssueWatch related things (#10401)
* refactor * optimize * remove Iretating function LoadWatchUsers do not load Users into IW object and it is used only in api ... so move this logic * remove unessesary * Apply suggestions from code review Thx Co-Authored-By: guillep2k <18600385+guillep2k@users.noreply.github.com> * make Tests more robust * fix rebase * restart CI * CI no dont hit sqlites deadlock Co-authored-by: guillep2k <18600385+guillep2k@users.noreply.github.com>
Diffstat (limited to 'models/notification.go')
-rw-r--r--models/notification.go66
1 files changed, 30 insertions, 36 deletions
diff --git a/models/notification.go b/models/notification.go
index e7217a6e04..c52d6c557a 100644
--- a/models/notification.go
+++ b/models/notification.go
@@ -133,55 +133,42 @@ func CreateOrUpdateIssueNotifications(issueID, commentID int64, notificationAuth
}
func createOrUpdateIssueNotifications(e Engine, issueID, commentID int64, notificationAuthorID int64) error {
- issueWatches, err := getIssueWatchers(e, issueID, ListOptions{})
+ // init
+ toNotify := make(map[int64]struct{}, 32)
+ notifications, err := getNotificationsByIssueID(e, issueID)
if err != nil {
return err
}
-
issue, err := getIssueByID(e, issueID)
if err != nil {
return err
}
- watches, err := getWatchers(e, issue.RepoID)
+ issueWatches, err := getIssueWatchersIDs(e, issueID, true)
if err != nil {
return err
}
+ for _, id := range issueWatches {
+ toNotify[id] = struct{}{}
+ }
- notifications, err := getNotificationsByIssueID(e, issueID)
+ repoWatches, err := getRepoWatchersIDs(e, issue.RepoID)
if err != nil {
return err
}
-
- alreadyNotified := make(map[int64]struct{}, len(issueWatches)+len(watches))
-
- notifyUser := func(userID int64) error {
- // do not send notification for the own issuer/commenter
- if userID == notificationAuthorID {
- return nil
- }
-
- if _, ok := alreadyNotified[userID]; ok {
- return nil
- }
- alreadyNotified[userID] = struct{}{}
-
- if notificationExists(notifications, issue.ID, userID) {
- return updateIssueNotification(e, userID, issue.ID, commentID, notificationAuthorID)
- }
- return createIssueNotification(e, userID, issue, commentID, notificationAuthorID)
+ for _, id := range repoWatches {
+ toNotify[id] = struct{}{}
}
- for _, issueWatch := range issueWatches {
- // ignore if user unwatched the issue
- if !issueWatch.IsWatching {
- alreadyNotified[issueWatch.UserID] = struct{}{}
- continue
- }
-
- if err := notifyUser(issueWatch.UserID); err != nil {
- return err
- }
+ // dont notify user who cause notification
+ delete(toNotify, notificationAuthorID)
+ // explicit unwatch on issue
+ issueUnWatches, err := getIssueWatchersIDs(e, issueID, false)
+ if err != nil {
+ return err
+ }
+ for _, id := range issueUnWatches {
+ delete(toNotify, id)
}
err = issue.loadRepo(e)
@@ -189,16 +176,23 @@ func createOrUpdateIssueNotifications(e Engine, issueID, commentID int64, notifi
return err
}
- for _, watch := range watches {
+ // notify
+ for userID := range toNotify {
issue.Repo.Units = nil
- if issue.IsPull && !issue.Repo.checkUnitUser(e, watch.UserID, false, UnitTypePullRequests) {
+ if issue.IsPull && !issue.Repo.checkUnitUser(e, userID, false, UnitTypePullRequests) {
continue
}
- if !issue.IsPull && !issue.Repo.checkUnitUser(e, watch.UserID, false, UnitTypeIssues) {
+ if !issue.IsPull && !issue.Repo.checkUnitUser(e, userID, false, UnitTypeIssues) {
continue
}
- if err := notifyUser(watch.UserID); err != nil {
+ if notificationExists(notifications, issue.ID, userID) {
+ if err = updateIssueNotification(e, userID, issue.ID, commentID, notificationAuthorID); err != nil {
+ return err
+ }
+ continue
+ }
+ if err = createIssueNotification(e, userID, issue, commentID, notificationAuthorID); err != nil {
return err
}
}