mirror of
https://github.com/go-gitea/gitea
synced 2025-01-18 08:57:43 +01:00
61db834904
* Adds functionality to change target branch of created pull requests Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Use const instead of var in JavaScript additions Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Check if branches are equal and if PR already exists before changing target branch Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Make sure to check all commits Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Print error messages for user as error flash message Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Disallow changing target branch of closed or merged pull requests Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Resolve conflicts after merge of upstream/master Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Change order of branch select fields Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Removes duplicate check Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Use ctx.Tr for translations Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Recompile JS Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Use correct translation namespace Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Remove redundant if condition Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Moves most change branch logic into pull service Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Completes comment Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Add Ref to ChangesPayload for logging changed target branches instead of creating a new struct Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Revert changes to go.mod Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Directly use createComment method Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Return 404 if pull request is not found. Move written check up Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Remove variable declaration Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Return client errors on change pull request target errors Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Return error in commit.HasPreviousCommit Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Adds blank line Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Test patch before persisting new target branch Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Update patch before testing (not working) Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Removes patch calls when changeing pull request target Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Removes unneeded check for base name Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Moves ChangeTargetBranch completely to pull service. Update patch status. Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Set webhook mode after errors were validated Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Update PR in one transaction Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Move logic for check if head is equal with branch to pull model Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Adds missing comment and simplify return Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Adjust CreateComment method call Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com>
258 lines
8.9 KiB
Go
258 lines
8.9 KiB
Go
// Copyright 2018 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 notification
|
|
|
|
import (
|
|
"code.gitea.io/gitea/models"
|
|
"code.gitea.io/gitea/modules/git"
|
|
"code.gitea.io/gitea/modules/notification/action"
|
|
"code.gitea.io/gitea/modules/notification/base"
|
|
"code.gitea.io/gitea/modules/notification/indexer"
|
|
"code.gitea.io/gitea/modules/notification/mail"
|
|
"code.gitea.io/gitea/modules/notification/ui"
|
|
"code.gitea.io/gitea/modules/notification/webhook"
|
|
"code.gitea.io/gitea/modules/setting"
|
|
)
|
|
|
|
var (
|
|
notifiers []base.Notifier
|
|
)
|
|
|
|
// RegisterNotifier providers method to receive notify messages
|
|
func RegisterNotifier(notifier base.Notifier) {
|
|
go notifier.Run()
|
|
notifiers = append(notifiers, notifier)
|
|
}
|
|
|
|
// NewContext registers notification handlers
|
|
func NewContext() {
|
|
RegisterNotifier(ui.NewNotifier())
|
|
if setting.Service.EnableNotifyMail {
|
|
RegisterNotifier(mail.NewNotifier())
|
|
}
|
|
RegisterNotifier(indexer.NewNotifier())
|
|
RegisterNotifier(webhook.NewNotifier())
|
|
RegisterNotifier(action.NewNotifier())
|
|
}
|
|
|
|
// NotifyCreateIssueComment notifies issue comment related message to notifiers
|
|
func NotifyCreateIssueComment(doer *models.User, repo *models.Repository,
|
|
issue *models.Issue, comment *models.Comment) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyCreateIssueComment(doer, repo, issue, comment)
|
|
}
|
|
}
|
|
|
|
// NotifyNewIssue notifies new issue to notifiers
|
|
func NotifyNewIssue(issue *models.Issue) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyNewIssue(issue)
|
|
}
|
|
}
|
|
|
|
// NotifyIssueChangeStatus notifies close or reopen issue to notifiers
|
|
func NotifyIssueChangeStatus(doer *models.User, issue *models.Issue, actionComment *models.Comment, closeOrReopen bool) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyIssueChangeStatus(doer, issue, actionComment, closeOrReopen)
|
|
}
|
|
}
|
|
|
|
// NotifyMergePullRequest notifies merge pull request to notifiers
|
|
func NotifyMergePullRequest(pr *models.PullRequest, doer *models.User, baseGitRepo *git.Repository) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyMergePullRequest(pr, doer, baseGitRepo)
|
|
}
|
|
}
|
|
|
|
// NotifyNewPullRequest notifies new pull request to notifiers
|
|
func NotifyNewPullRequest(pr *models.PullRequest) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyNewPullRequest(pr)
|
|
}
|
|
}
|
|
|
|
// NotifyPullRequestSynchronized notifies Synchronized pull request
|
|
func NotifyPullRequestSynchronized(doer *models.User, pr *models.PullRequest) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyPullRequestSynchronized(doer, pr)
|
|
}
|
|
}
|
|
|
|
// NotifyPullRequestReview notifies new pull request review
|
|
func NotifyPullRequestReview(pr *models.PullRequest, review *models.Review, comment *models.Comment) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyPullRequestReview(pr, review, comment)
|
|
}
|
|
}
|
|
|
|
// NotifyPullRequestChangeTargetBranch notifies when a pull request's target branch was changed
|
|
func NotifyPullRequestChangeTargetBranch(doer *models.User, pr *models.PullRequest, oldBranch string) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyPullRequestChangeTargetBranch(doer, pr, oldBranch)
|
|
}
|
|
}
|
|
|
|
// NotifyUpdateComment notifies update comment to notifiers
|
|
func NotifyUpdateComment(doer *models.User, c *models.Comment, oldContent string) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyUpdateComment(doer, c, oldContent)
|
|
}
|
|
}
|
|
|
|
// NotifyDeleteComment notifies delete comment to notifiers
|
|
func NotifyDeleteComment(doer *models.User, c *models.Comment) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyDeleteComment(doer, c)
|
|
}
|
|
}
|
|
|
|
// NotifyNewRelease notifies new release to notifiers
|
|
func NotifyNewRelease(rel *models.Release) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyNewRelease(rel)
|
|
}
|
|
}
|
|
|
|
// NotifyUpdateRelease notifies update release to notifiers
|
|
func NotifyUpdateRelease(doer *models.User, rel *models.Release) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyUpdateRelease(doer, rel)
|
|
}
|
|
}
|
|
|
|
// NotifyDeleteRelease notifies delete release to notifiers
|
|
func NotifyDeleteRelease(doer *models.User, rel *models.Release) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyDeleteRelease(doer, rel)
|
|
}
|
|
}
|
|
|
|
// NotifyIssueChangeMilestone notifies change milestone to notifiers
|
|
func NotifyIssueChangeMilestone(doer *models.User, issue *models.Issue, oldMilestoneID int64) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyIssueChangeMilestone(doer, issue, oldMilestoneID)
|
|
}
|
|
}
|
|
|
|
// NotifyIssueChangeContent notifies change content to notifiers
|
|
func NotifyIssueChangeContent(doer *models.User, issue *models.Issue, oldContent string) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyIssueChangeContent(doer, issue, oldContent)
|
|
}
|
|
}
|
|
|
|
// NotifyIssueChangeAssignee notifies change content to notifiers
|
|
func NotifyIssueChangeAssignee(doer *models.User, issue *models.Issue, assignee *models.User, removed bool, comment *models.Comment) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyIssueChangeAssignee(doer, issue, assignee, removed, comment)
|
|
}
|
|
}
|
|
|
|
// NotifyIssueClearLabels notifies clear labels to notifiers
|
|
func NotifyIssueClearLabels(doer *models.User, issue *models.Issue) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyIssueClearLabels(doer, issue)
|
|
}
|
|
}
|
|
|
|
// NotifyIssueChangeTitle notifies change title to notifiers
|
|
func NotifyIssueChangeTitle(doer *models.User, issue *models.Issue, oldTitle string) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyIssueChangeTitle(doer, issue, oldTitle)
|
|
}
|
|
}
|
|
|
|
// NotifyIssueChangeLabels notifies change labels to notifiers
|
|
func NotifyIssueChangeLabels(doer *models.User, issue *models.Issue,
|
|
addedLabels []*models.Label, removedLabels []*models.Label) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyIssueChangeLabels(doer, issue, addedLabels, removedLabels)
|
|
}
|
|
}
|
|
|
|
// NotifyCreateRepository notifies create repository to notifiers
|
|
func NotifyCreateRepository(doer *models.User, u *models.User, repo *models.Repository) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyCreateRepository(doer, u, repo)
|
|
}
|
|
}
|
|
|
|
// NotifyMigrateRepository notifies create repository to notifiers
|
|
func NotifyMigrateRepository(doer *models.User, u *models.User, repo *models.Repository) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyMigrateRepository(doer, u, repo)
|
|
}
|
|
}
|
|
|
|
// NotifyTransferRepository notifies create repository to notifiers
|
|
func NotifyTransferRepository(doer *models.User, repo *models.Repository, newOwnerName string) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyTransferRepository(doer, repo, newOwnerName)
|
|
}
|
|
}
|
|
|
|
// NotifyDeleteRepository notifies delete repository to notifiers
|
|
func NotifyDeleteRepository(doer *models.User, repo *models.Repository) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyDeleteRepository(doer, repo)
|
|
}
|
|
}
|
|
|
|
// NotifyForkRepository notifies fork repository to notifiers
|
|
func NotifyForkRepository(doer *models.User, oldRepo, repo *models.Repository) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyForkRepository(doer, oldRepo, repo)
|
|
}
|
|
}
|
|
|
|
// NotifyRenameRepository notifies repository renamed
|
|
func NotifyRenameRepository(doer *models.User, repo *models.Repository, oldName string) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyRenameRepository(doer, repo, oldName)
|
|
}
|
|
}
|
|
|
|
// NotifyPushCommits notifies commits pushed to notifiers
|
|
func NotifyPushCommits(pusher *models.User, repo *models.Repository, refName, oldCommitID, newCommitID string, commits *models.PushCommits) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyPushCommits(pusher, repo, refName, oldCommitID, newCommitID, commits)
|
|
}
|
|
}
|
|
|
|
// NotifyCreateRef notifies branch or tag creation to notifiers
|
|
func NotifyCreateRef(pusher *models.User, repo *models.Repository, refType, refFullName string) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyCreateRef(pusher, repo, refType, refFullName)
|
|
}
|
|
}
|
|
|
|
// NotifyDeleteRef notifies branch or tag deletion to notifiers
|
|
func NotifyDeleteRef(pusher *models.User, repo *models.Repository, refType, refFullName string) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifyDeleteRef(pusher, repo, refType, refFullName)
|
|
}
|
|
}
|
|
|
|
// NotifySyncPushCommits notifies commits pushed to notifiers
|
|
func NotifySyncPushCommits(pusher *models.User, repo *models.Repository, refName, oldCommitID, newCommitID string, commits *models.PushCommits) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifySyncPushCommits(pusher, repo, refName, oldCommitID, newCommitID, commits)
|
|
}
|
|
}
|
|
|
|
// NotifySyncCreateRef notifies branch or tag creation to notifiers
|
|
func NotifySyncCreateRef(pusher *models.User, repo *models.Repository, refType, refFullName string) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifySyncCreateRef(pusher, repo, refType, refFullName)
|
|
}
|
|
}
|
|
|
|
// NotifySyncDeleteRef notifies branch or tag deletion to notifiers
|
|
func NotifySyncDeleteRef(pusher *models.User, repo *models.Repository, refType, refFullName string) {
|
|
for _, notifier := range notifiers {
|
|
notifier.NotifySyncDeleteRef(pusher, repo, refType, refFullName)
|
|
}
|
|
}
|