diff options
author | Harshit Bansal <harshitbansal2015@gmail.com> | 2019-01-04 14:52:58 +0530 |
---|---|---|
committer | Lauris BH <lauris@nix.lv> | 2019-01-04 11:22:58 +0200 |
commit | 9f476b8d1e8eb8f576fad208701a4dc3d8e7108f (patch) | |
tree | 7d8e75311c78f8a7f6d9327e62fdc414643ee689 /models/action.go | |
parent | 0de57fd57ca1a268e084d322c3e0f2d054b931e2 (diff) | |
download | gitea-9f476b8d1e8eb8f576fad208701a4dc3d8e7108f.tar.gz gitea-9f476b8d1e8eb8f576fad208701a4dc3d8e7108f.zip |
Don't close issues via commits on non-default branch. (#5622)
Adds a small check to close the issues only if the referencing commits
are on the default branch.
Fixes: #2314.
Diffstat (limited to 'models/action.go')
-rw-r--r-- | models/action.go | 74 |
1 files changed, 35 insertions, 39 deletions
diff --git a/models/action.go b/models/action.go index cde0fb080e..d917c37746 100644 --- a/models/action.go +++ b/models/action.go @@ -476,8 +476,34 @@ func getIssueFromRef(repo *Repository, ref string) (*Issue, error) { return issue, nil } +func changeIssueStatus(repo *Repository, doer *User, ref string, refMarked map[int64]bool, status bool) error { + issue, err := getIssueFromRef(repo, ref) + if err != nil { + return err + } + + if issue == nil || refMarked[issue.ID] { + return nil + } + refMarked[issue.ID] = true + + if issue.RepoID != repo.ID || issue.IsClosed == status { + return nil + } + + issue.Repo = repo + if err = issue.ChangeStatus(doer, status); err != nil { + // Don't return an error when dependencies are open as this would let the push fail + if IsErrDependenciesLeft(err) { + return nil + } + return err + } + return nil +} + // UpdateIssuesCommit checks if issues are manipulated by commit message. -func UpdateIssuesCommit(doer *User, repo *Repository, commits []*PushCommit) error { +func UpdateIssuesCommit(doer *User, repo *Repository, commits []*PushCommit, branchName string) error { // Commits are appended in the reverse order. for i := len(commits) - 1; i >= 0; i-- { c := commits[i] @@ -500,51 +526,21 @@ func UpdateIssuesCommit(doer *User, repo *Repository, commits []*PushCommit) err } } + // Change issue status only if the commit has been pushed to the default branch. + if repo.DefaultBranch != branchName { + continue + } + refMarked = make(map[int64]bool) - // FIXME: can merge this one and next one to a common function. for _, ref := range issueCloseKeywordsPat.FindAllString(c.Message, -1) { - issue, err := getIssueFromRef(repo, ref) - if err != nil { - return err - } - - if issue == nil || refMarked[issue.ID] { - continue - } - refMarked[issue.ID] = true - - if issue.RepoID != repo.ID || issue.IsClosed { - continue - } - - issue.Repo = repo - if err = issue.ChangeStatus(doer, true); err != nil { - // Don't return an error when dependencies are open as this would let the push fail - if IsErrDependenciesLeft(err) { - return nil - } + if err := changeIssueStatus(repo, doer, ref, refMarked, true); err != nil { return err } } // It is conflict to have close and reopen at same time, so refsMarked doesn't need to reinit here. for _, ref := range issueReopenKeywordsPat.FindAllString(c.Message, -1) { - issue, err := getIssueFromRef(repo, ref) - if err != nil { - return err - } - - if issue == nil || refMarked[issue.ID] { - continue - } - refMarked[issue.ID] = true - - if issue.RepoID != repo.ID || !issue.IsClosed { - continue - } - - issue.Repo = repo - if err = issue.ChangeStatus(doer, false); err != nil { + if err := changeIssueStatus(repo, doer, ref, refMarked, false); err != nil { return err } } @@ -609,7 +605,7 @@ func CommitRepoAction(opts CommitRepoActionOptions) error { opts.Commits.CompareURL = repo.ComposeCompareURL(opts.OldCommitID, opts.NewCommitID) } - if err = UpdateIssuesCommit(pusher, repo, opts.Commits.Commits); err != nil { + if err = UpdateIssuesCommit(pusher, repo, opts.Commits.Commits, refName); err != nil { log.Error(4, "updateIssuesCommit: %v", err) } } |