Move mirror sync actions to notification (#9022)
* Move mirror sync actions to notification * fix lint
This commit is contained in:
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)
|
|
||||||
}
|
|
Loading…
Reference in a new issue