mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-31 21:28:11 +09:00 
			
		
		
		
	Move mirror sync actions to notification (#9022)
* Move mirror sync actions to notification * fix lint
This commit is contained in:
		
				
					committed by
					
						 techknowlogick
						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