mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 16:40:24 +08:00 
			
		
		
		
	Move mirror sync actions to notification (#9022)
* Move mirror sync actions to notification * fix lint
This commit is contained in:
		
				
					committed by
					
						
						techknowlogick
					
				
			
			
				
	
			
			
			
						parent
						
							e3f22ad2cc
						
					
				
				
					commit
					8ab35eefc4
				
			@@ -88,6 +88,19 @@ func RefEndName(refStr string) string {
 | 
				
			|||||||
	return refStr
 | 
						return refStr
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// SplitRefName splits a full refname to reftype and simple refname
 | 
				
			||||||
 | 
					func SplitRefName(refStr string) (string, string) {
 | 
				
			||||||
 | 
						if strings.HasPrefix(refStr, BranchPrefix) {
 | 
				
			||||||
 | 
							return BranchPrefix, refStr[len(BranchPrefix):]
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if strings.HasPrefix(refStr, TagPrefix) {
 | 
				
			||||||
 | 
							return TagPrefix, refStr[len(TagPrefix):]
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return "", refStr
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// ParseBool returns the boolean value represented by the string as per git's git_config_bool
 | 
					// ParseBool returns the boolean value represented by the string as per git's git_config_bool
 | 
				
			||||||
// true will be returned for the result if the string is empty, but valid will be false.
 | 
					// true will be returned for the result if the string is empty, but valid will be false.
 | 
				
			||||||
// "true", "yes", "on" are all true, true
 | 
					// "true", "yes", "on" are all true, true
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,6 +5,7 @@
 | 
				
			|||||||
package action
 | 
					package action
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import (
 | 
					import (
 | 
				
			||||||
 | 
						"encoding/json"
 | 
				
			||||||
	"fmt"
 | 
						"fmt"
 | 
				
			||||||
	"path"
 | 
						"path"
 | 
				
			||||||
	"strings"
 | 
						"strings"
 | 
				
			||||||
@@ -206,3 +207,52 @@ func (*actionNotifier) NotifyMergePullRequest(pr *models.PullRequest, doer *mode
 | 
				
			|||||||
		log.Error("NotifyWatchers [%d]: %v", pr.ID, err)
 | 
							log.Error("NotifyWatchers [%d]: %v", pr.ID, err)
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (a *actionNotifier) NotifySyncPushCommits(pusher *models.User, repo *models.Repository, refName, oldCommitID, newCommitID string, commits *models.PushCommits) {
 | 
				
			||||||
 | 
						data, err := json.Marshal(commits)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							log.Error("json.Marshal: %v", err)
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if err := models.NotifyWatchers(&models.Action{
 | 
				
			||||||
 | 
							ActUserID: repo.OwnerID,
 | 
				
			||||||
 | 
							ActUser:   repo.MustOwner(),
 | 
				
			||||||
 | 
							OpType:    models.ActionMirrorSyncPush,
 | 
				
			||||||
 | 
							RepoID:    repo.ID,
 | 
				
			||||||
 | 
							Repo:      repo,
 | 
				
			||||||
 | 
							IsPrivate: repo.IsPrivate,
 | 
				
			||||||
 | 
							RefName:   refName,
 | 
				
			||||||
 | 
							Content:   string(data),
 | 
				
			||||||
 | 
						}); err != nil {
 | 
				
			||||||
 | 
							log.Error("notifyWatchers: %v", err)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (a *actionNotifier) NotifySyncCreateRef(doer *models.User, repo *models.Repository, refType, refFullName string) {
 | 
				
			||||||
 | 
						if err := models.NotifyWatchers(&models.Action{
 | 
				
			||||||
 | 
							ActUserID: repo.OwnerID,
 | 
				
			||||||
 | 
							ActUser:   repo.MustOwner(),
 | 
				
			||||||
 | 
							OpType:    models.ActionMirrorSyncCreate,
 | 
				
			||||||
 | 
							RepoID:    repo.ID,
 | 
				
			||||||
 | 
							Repo:      repo,
 | 
				
			||||||
 | 
							IsPrivate: repo.IsPrivate,
 | 
				
			||||||
 | 
							RefName:   refFullName,
 | 
				
			||||||
 | 
						}); err != nil {
 | 
				
			||||||
 | 
							log.Error("notifyWatchers: %v", err)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (a *actionNotifier) NotifySyncDeleteRef(doer *models.User, repo *models.Repository, refType, refFullName string) {
 | 
				
			||||||
 | 
						if err := models.NotifyWatchers(&models.Action{
 | 
				
			||||||
 | 
							ActUserID: repo.OwnerID,
 | 
				
			||||||
 | 
							ActUser:   repo.MustOwner(),
 | 
				
			||||||
 | 
							OpType:    models.ActionMirrorSyncCreate,
 | 
				
			||||||
 | 
							RepoID:    repo.ID,
 | 
				
			||||||
 | 
							Repo:      repo,
 | 
				
			||||||
 | 
							IsPrivate: repo.IsPrivate,
 | 
				
			||||||
 | 
							RefName:   refFullName,
 | 
				
			||||||
 | 
						}); err != nil {
 | 
				
			||||||
 | 
							log.Error("notifyWatchers: %v", err)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -47,4 +47,8 @@ type Notifier interface {
 | 
				
			|||||||
	NotifyPushCommits(pusher *models.User, repo *models.Repository, refName, oldCommitID, newCommitID string, commits *models.PushCommits)
 | 
						NotifyPushCommits(pusher *models.User, repo *models.Repository, refName, oldCommitID, newCommitID string, commits *models.PushCommits)
 | 
				
			||||||
	NotifyCreateRef(doer *models.User, repo *models.Repository, refType, refFullName string)
 | 
						NotifyCreateRef(doer *models.User, repo *models.Repository, refType, refFullName string)
 | 
				
			||||||
	NotifyDeleteRef(doer *models.User, repo *models.Repository, refType, refFullName string)
 | 
						NotifyDeleteRef(doer *models.User, repo *models.Repository, refType, refFullName string)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						NotifySyncPushCommits(pusher *models.User, repo *models.Repository, refName, oldCommitID, newCommitID string, commits *models.PushCommits)
 | 
				
			||||||
 | 
						NotifySyncCreateRef(doer *models.User, repo *models.Repository, refType, refFullName string)
 | 
				
			||||||
 | 
						NotifySyncDeleteRef(doer *models.User, repo *models.Repository, refType, refFullName string)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -130,3 +130,15 @@ func (*NullNotifier) NotifyRenameRepository(doer *models.User, repo *models.Repo
 | 
				
			|||||||
// NotifyTransferRepository places a place holder function
 | 
					// NotifyTransferRepository places a place holder function
 | 
				
			||||||
func (*NullNotifier) NotifyTransferRepository(doer *models.User, repo *models.Repository, oldOwnerName string) {
 | 
					func (*NullNotifier) NotifyTransferRepository(doer *models.User, repo *models.Repository, oldOwnerName string) {
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// NotifySyncPushCommits places a place holder function
 | 
				
			||||||
 | 
					func (*NullNotifier) NotifySyncPushCommits(pusher *models.User, repo *models.Repository, refName, oldCommitID, newCommitID string, commits *models.PushCommits) {
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// NotifySyncCreateRef places a place holder function
 | 
				
			||||||
 | 
					func (*NullNotifier) NotifySyncCreateRef(doer *models.User, repo *models.Repository, refType, refFullName string) {
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// NotifySyncDeleteRef places a place holder function
 | 
				
			||||||
 | 
					func (*NullNotifier) NotifySyncDeleteRef(doer *models.User, repo *models.Repository, refType, refFullName string) {
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -227,3 +227,24 @@ func NotifyDeleteRef(pusher *models.User, repo *models.Repository, refType, refF
 | 
				
			|||||||
		notifier.NotifyDeleteRef(pusher, repo, refType, refFullName)
 | 
							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)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -695,3 +695,25 @@ func (m *webhookNotifier) NotifyUpdateRelease(doer *models.User, rel *models.Rel
 | 
				
			|||||||
func (m *webhookNotifier) NotifyDeleteRelease(doer *models.User, rel *models.Release) {
 | 
					func (m *webhookNotifier) NotifyDeleteRelease(doer *models.User, rel *models.Release) {
 | 
				
			||||||
	sendReleaseHook(doer, rel, api.HookReleaseDeleted)
 | 
						sendReleaseHook(doer, rel, api.HookReleaseDeleted)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (m *webhookNotifier) NotifySyncPushCommits(pusher *models.User, repo *models.Repository, refName, oldCommitID, newCommitID string, commits *models.PushCommits) {
 | 
				
			||||||
 | 
						apiPusher := pusher.APIFormat()
 | 
				
			||||||
 | 
						apiCommits, err := commits.ToAPIPayloadCommits(repo.RepoPath(), repo.HTMLURL())
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							log.Error("commits.ToAPIPayloadCommits failed: %v", err)
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if err := webhook_module.PrepareWebhooks(repo, models.HookEventPush, &api.PushPayload{
 | 
				
			||||||
 | 
							Ref:        refName,
 | 
				
			||||||
 | 
							Before:     oldCommitID,
 | 
				
			||||||
 | 
							After:      newCommitID,
 | 
				
			||||||
 | 
							CompareURL: setting.AppURL + commits.CompareURL,
 | 
				
			||||||
 | 
							Commits:    apiCommits,
 | 
				
			||||||
 | 
							Repo:       repo.APIFormat(models.AccessModeOwner),
 | 
				
			||||||
 | 
							Pusher:     apiPusher,
 | 
				
			||||||
 | 
							Sender:     apiPusher,
 | 
				
			||||||
 | 
						}); err != nil {
 | 
				
			||||||
 | 
							log.Error("PrepareWebhooks: %v", err)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -14,6 +14,7 @@ import (
 | 
				
			|||||||
	"code.gitea.io/gitea/modules/cache"
 | 
						"code.gitea.io/gitea/modules/cache"
 | 
				
			||||||
	"code.gitea.io/gitea/modules/git"
 | 
						"code.gitea.io/gitea/modules/git"
 | 
				
			||||||
	"code.gitea.io/gitea/modules/log"
 | 
						"code.gitea.io/gitea/modules/log"
 | 
				
			||||||
 | 
						"code.gitea.io/gitea/modules/notification"
 | 
				
			||||||
	"code.gitea.io/gitea/modules/process"
 | 
						"code.gitea.io/gitea/modules/process"
 | 
				
			||||||
	"code.gitea.io/gitea/modules/setting"
 | 
						"code.gitea.io/gitea/modules/setting"
 | 
				
			||||||
	"code.gitea.io/gitea/modules/sync"
 | 
						"code.gitea.io/gitea/modules/sync"
 | 
				
			||||||
@@ -336,19 +337,17 @@ func syncMirror(repoID string) {
 | 
				
			|||||||
			continue
 | 
								continue
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							tp, _ := git.SplitRefName(result.refName)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		// Create reference
 | 
							// Create reference
 | 
				
			||||||
		if result.oldCommitID == gitShortEmptySha {
 | 
							if result.oldCommitID == gitShortEmptySha {
 | 
				
			||||||
			if err = SyncCreateAction(m.Repo, result.refName); err != nil {
 | 
								notification.NotifySyncCreateRef(m.Repo.MustOwner(), m.Repo, tp, result.refName)
 | 
				
			||||||
				log.Error("SyncCreateAction [repo_id: %d]: %v", m.RepoID, err)
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
			continue
 | 
								continue
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		// Delete reference
 | 
							// Delete reference
 | 
				
			||||||
		if result.newCommitID == gitShortEmptySha {
 | 
							if result.newCommitID == gitShortEmptySha {
 | 
				
			||||||
			if err = SyncDeleteAction(m.Repo, result.refName); err != nil {
 | 
								notification.NotifySyncDeleteRef(m.Repo.MustOwner(), m.Repo, tp, result.refName)
 | 
				
			||||||
				log.Error("SyncDeleteAction [repo_id: %d]: %v", m.RepoID, err)
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
			continue
 | 
								continue
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -368,15 +367,15 @@ func syncMirror(repoID string) {
 | 
				
			|||||||
			log.Error("CommitsBetweenIDs [repo_id: %d, new_commit_id: %s, old_commit_id: %s]: %v", m.RepoID, newCommitID, oldCommitID, err)
 | 
								log.Error("CommitsBetweenIDs [repo_id: %d, new_commit_id: %s, old_commit_id: %s]: %v", m.RepoID, newCommitID, oldCommitID, err)
 | 
				
			||||||
			continue
 | 
								continue
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		if err = SyncPushAction(m.Repo, SyncPushActionOptions{
 | 
					
 | 
				
			||||||
			RefName:     result.refName,
 | 
							theCommits := models.ListToPushCommits(commits)
 | 
				
			||||||
			OldCommitID: oldCommitID,
 | 
							if len(theCommits.Commits) > setting.UI.FeedMaxCommitNum {
 | 
				
			||||||
			NewCommitID: newCommitID,
 | 
								theCommits.Commits = theCommits.Commits[:setting.UI.FeedMaxCommitNum]
 | 
				
			||||||
			Commits:     models.ListToPushCommits(commits),
 | 
					 | 
				
			||||||
		}); err != nil {
 | 
					 | 
				
			||||||
			log.Error("SyncPushAction [repo_id: %d]: %v", m.RepoID, err)
 | 
					 | 
				
			||||||
			continue
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							theCommits.CompareURL = m.Repo.ComposeCompareURL(oldCommitID, newCommitID)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							notification.NotifySyncPushCommits(m.Repo.MustOwner(), m.Repo, result.refName, oldCommitID, newCommitID, models.ListToPushCommits(commits))
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	// Get latest commit date and update to current repository updated time
 | 
						// Get latest commit date and update to current repository updated time
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,67 +0,0 @@
 | 
				
			|||||||
// 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 mirror
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import (
 | 
					 | 
				
			||||||
	"encoding/json"
 | 
					 | 
				
			||||||
	"fmt"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	"code.gitea.io/gitea/models"
 | 
					 | 
				
			||||||
	"code.gitea.io/gitea/modules/notification"
 | 
					 | 
				
			||||||
	"code.gitea.io/gitea/modules/setting"
 | 
					 | 
				
			||||||
)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
func syncAction(opType models.ActionType, repo *models.Repository, refName string, data []byte) error {
 | 
					 | 
				
			||||||
	if err := models.NotifyWatchers(&models.Action{
 | 
					 | 
				
			||||||
		ActUserID: repo.OwnerID,
 | 
					 | 
				
			||||||
		ActUser:   repo.MustOwner(),
 | 
					 | 
				
			||||||
		OpType:    opType,
 | 
					 | 
				
			||||||
		RepoID:    repo.ID,
 | 
					 | 
				
			||||||
		Repo:      repo,
 | 
					 | 
				
			||||||
		IsPrivate: repo.IsPrivate,
 | 
					 | 
				
			||||||
		RefName:   refName,
 | 
					 | 
				
			||||||
		Content:   string(data),
 | 
					 | 
				
			||||||
	}); err != nil {
 | 
					 | 
				
			||||||
		return fmt.Errorf("notifyWatchers: %v", err)
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return nil
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// SyncPushActionOptions mirror synchronization action options.
 | 
					 | 
				
			||||||
type SyncPushActionOptions struct {
 | 
					 | 
				
			||||||
	RefName     string
 | 
					 | 
				
			||||||
	OldCommitID string
 | 
					 | 
				
			||||||
	NewCommitID string
 | 
					 | 
				
			||||||
	Commits     *models.PushCommits
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// SyncPushAction adds new action for mirror synchronization of pushed commits.
 | 
					 | 
				
			||||||
func SyncPushAction(repo *models.Repository, opts SyncPushActionOptions) error {
 | 
					 | 
				
			||||||
	if len(opts.Commits.Commits) > setting.UI.FeedMaxCommitNum {
 | 
					 | 
				
			||||||
		opts.Commits.Commits = opts.Commits.Commits[:setting.UI.FeedMaxCommitNum]
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	opts.Commits.CompareURL = repo.ComposeCompareURL(opts.OldCommitID, opts.NewCommitID)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	notification.NotifyPushCommits(repo.MustOwner(), repo, opts.RefName, opts.OldCommitID, opts.NewCommitID, opts.Commits)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	data, err := json.Marshal(opts.Commits)
 | 
					 | 
				
			||||||
	if err != nil {
 | 
					 | 
				
			||||||
		return err
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return syncAction(models.ActionMirrorSyncPush, repo, opts.RefName, data)
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// SyncCreateAction adds new action for mirror synchronization of new reference.
 | 
					 | 
				
			||||||
func SyncCreateAction(repo *models.Repository, refName string) error {
 | 
					 | 
				
			||||||
	return syncAction(models.ActionMirrorSyncCreate, repo, refName, nil)
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// SyncDeleteAction adds new action for mirror synchronization of delete reference.
 | 
					 | 
				
			||||||
func SyncDeleteAction(repo *models.Repository, refName string) error {
 | 
					 | 
				
			||||||
	return syncAction(models.ActionMirrorSyncDelete, repo, refName, nil)
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
		Reference in New Issue
	
	Block a user