2019-01-17 17:23:22 +03:00
// 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 indexer
import (
"code.gitea.io/gitea/models"
2021-11-24 12:49:20 +03:00
user_model "code.gitea.io/gitea/models/user"
2020-01-24 21:00:49 +03:00
"code.gitea.io/gitea/modules/git"
2019-12-08 22:15:35 +03:00
code_indexer "code.gitea.io/gitea/modules/indexer/code"
2019-02-21 03:54:05 +03:00
issue_indexer "code.gitea.io/gitea/modules/indexer/issues"
2020-02-11 12:34:17 +03:00
stats_indexer "code.gitea.io/gitea/modules/indexer/stats"
2019-02-19 17:39:39 +03:00
"code.gitea.io/gitea/modules/log"
2019-01-17 17:23:22 +03:00
"code.gitea.io/gitea/modules/notification/base"
2020-01-10 12:34:21 +03:00
"code.gitea.io/gitea/modules/repository"
2019-12-08 22:15:35 +03:00
"code.gitea.io/gitea/modules/setting"
2019-01-17 17:23:22 +03:00
)
type indexerNotifier struct {
base . NullNotifier
}
var (
_ base . Notifier = & indexerNotifier { }
)
// NewNotifier create a new indexerNotifier notifier
func NewNotifier ( ) base . Notifier {
return & indexerNotifier { }
}
2021-11-24 12:49:20 +03:00
func ( r * indexerNotifier ) NotifyCreateIssueComment ( doer * user_model . User , repo * models . Repository ,
issue * models . Issue , comment * models . Comment , mentions [ ] * user_model . User ) {
2019-01-17 17:23:22 +03:00
if comment . Type == models . CommentTypeComment {
2019-02-19 17:39:39 +03:00
if issue . Comments == nil {
if err := issue . LoadDiscussComments ( ) ; err != nil {
2019-04-02 10:48:31 +03:00
log . Error ( "LoadComments failed: %v" , err )
2019-02-19 17:39:39 +03:00
return
}
} else {
issue . Comments = append ( issue . Comments , comment )
}
2019-02-21 03:54:05 +03:00
issue_indexer . UpdateIssueIndexer ( issue )
2019-01-17 17:23:22 +03:00
}
}
2021-11-24 12:49:20 +03:00
func ( r * indexerNotifier ) NotifyNewIssue ( issue * models . Issue , mentions [ ] * user_model . User ) {
2019-02-21 03:54:05 +03:00
issue_indexer . UpdateIssueIndexer ( issue )
2019-01-17 17:23:22 +03:00
}
2021-11-24 12:49:20 +03:00
func ( r * indexerNotifier ) NotifyNewPullRequest ( pr * models . PullRequest , mentions [ ] * user_model . User ) {
2019-02-21 03:54:05 +03:00
issue_indexer . UpdateIssueIndexer ( pr . Issue )
2019-01-17 17:23:22 +03:00
}
2021-11-24 12:49:20 +03:00
func ( r * indexerNotifier ) NotifyUpdateComment ( doer * user_model . User , c * models . Comment , oldContent string ) {
2019-01-17 17:23:22 +03:00
if c . Type == models . CommentTypeComment {
2019-02-19 17:39:39 +03:00
var found bool
if c . Issue . Comments != nil {
for i := 0 ; i < len ( c . Issue . Comments ) ; i ++ {
if c . Issue . Comments [ i ] . ID == c . ID {
c . Issue . Comments [ i ] = c
found = true
break
}
}
}
if ! found {
if err := c . Issue . LoadDiscussComments ( ) ; err != nil {
2019-04-02 10:48:31 +03:00
log . Error ( "LoadComments failed: %v" , err )
2019-02-19 17:39:39 +03:00
return
}
}
2019-02-21 03:54:05 +03:00
issue_indexer . UpdateIssueIndexer ( c . Issue )
2019-01-17 17:23:22 +03:00
}
}
2021-11-24 12:49:20 +03:00
func ( r * indexerNotifier ) NotifyDeleteComment ( doer * user_model . User , comment * models . Comment ) {
2019-01-17 17:23:22 +03:00
if comment . Type == models . CommentTypeComment {
2019-10-30 13:02:46 +03:00
if err := comment . LoadIssue ( ) ; err != nil {
log . Error ( "LoadIssue: %v" , err )
return
}
2019-02-19 17:39:39 +03:00
var found bool
if comment . Issue . Comments != nil {
for i := 0 ; i < len ( comment . Issue . Comments ) ; i ++ {
if comment . Issue . Comments [ i ] . ID == comment . ID {
comment . Issue . Comments = append ( comment . Issue . Comments [ : i ] , comment . Issue . Comments [ i + 1 : ] ... )
found = true
break
}
}
}
if ! found {
if err := comment . Issue . LoadDiscussComments ( ) ; err != nil {
2019-04-02 10:48:31 +03:00
log . Error ( "LoadComments failed: %v" , err )
2019-02-19 17:39:39 +03:00
return
}
}
// reload comments to delete the old comment
2019-02-21 03:54:05 +03:00
issue_indexer . UpdateIssueIndexer ( comment . Issue )
2019-01-17 17:23:22 +03:00
}
}
2021-11-24 12:49:20 +03:00
func ( r * indexerNotifier ) NotifyDeleteRepository ( doer * user_model . User , repo * models . Repository ) {
2019-02-21 03:54:05 +03:00
issue_indexer . DeleteRepoIssueIndexer ( repo )
2019-12-08 22:15:35 +03:00
if setting . Indexer . RepoIndexerEnabled {
2021-11-02 06:14:24 +03:00
code_indexer . UpdateRepoIndexer ( repo )
2019-12-08 22:15:35 +03:00
}
}
2021-11-24 12:49:20 +03:00
func ( r * indexerNotifier ) NotifyMigrateRepository ( doer * user_model . User , u * user_model . User , repo * models . Repository ) {
2019-12-13 00:46:43 +03:00
issue_indexer . UpdateRepoIndexer ( repo )
2019-12-08 22:15:35 +03:00
if setting . Indexer . RepoIndexerEnabled && ! repo . IsEmpty {
code_indexer . UpdateRepoIndexer ( repo )
}
2020-02-11 12:34:17 +03:00
if err := stats_indexer . UpdateRepoIndexer ( repo ) ; err != nil {
log . Error ( "stats_indexer.UpdateRepoIndexer(%d) failed: %v" , repo . ID , err )
}
2019-12-08 22:15:35 +03:00
}
2021-11-24 12:49:20 +03:00
func ( r * indexerNotifier ) NotifyPushCommits ( pusher * user_model . User , repo * models . Repository , opts * repository . PushUpdateOptions , commits * repository . PushCommits ) {
2020-10-31 00:59:02 +03:00
if setting . Indexer . RepoIndexerEnabled && opts . RefFullName == git . BranchPrefix + repo . DefaultBranch {
2019-12-08 22:15:35 +03:00
code_indexer . UpdateRepoIndexer ( repo )
}
2020-02-11 12:34:17 +03:00
if err := stats_indexer . UpdateRepoIndexer ( repo ) ; err != nil {
log . Error ( "stats_indexer.UpdateRepoIndexer(%d) failed: %v" , repo . ID , err )
}
2019-01-17 17:23:22 +03:00
}
2021-11-24 12:49:20 +03:00
func ( r * indexerNotifier ) NotifySyncPushCommits ( pusher * user_model . User , repo * models . Repository , opts * repository . PushUpdateOptions , commits * repository . PushCommits ) {
2020-10-31 00:59:02 +03:00
if setting . Indexer . RepoIndexerEnabled && opts . RefFullName == git . BranchPrefix + repo . DefaultBranch {
2020-05-08 17:58:40 +03:00
code_indexer . UpdateRepoIndexer ( repo )
}
if err := stats_indexer . UpdateRepoIndexer ( repo ) ; err != nil {
log . Error ( "stats_indexer.UpdateRepoIndexer(%d) failed: %v" , repo . ID , err )
}
}
2021-11-24 12:49:20 +03:00
func ( r * indexerNotifier ) NotifyIssueChangeContent ( doer * user_model . User , issue * models . Issue , oldContent string ) {
2019-02-21 03:54:05 +03:00
issue_indexer . UpdateIssueIndexer ( issue )
2019-01-17 17:23:22 +03:00
}
2021-11-24 12:49:20 +03:00
func ( r * indexerNotifier ) NotifyIssueChangeTitle ( doer * user_model . User , issue * models . Issue , oldTitle string ) {
2019-02-21 03:54:05 +03:00
issue_indexer . UpdateIssueIndexer ( issue )
2019-01-17 17:23:22 +03:00
}
2020-09-08 19:29:51 +03:00
2021-11-24 12:49:20 +03:00
func ( r * indexerNotifier ) NotifyIssueChangeRef ( doer * user_model . User , issue * models . Issue , oldRef string ) {
2020-09-08 19:29:51 +03:00
issue_indexer . UpdateIssueIndexer ( issue )
}