Move PushUpdate dependency from models to repofiles (#6763)
* remove push_update * move models.PushUpdate to repofiles.PushUpdate
This commit is contained in:
		
					parent
					
						
							
								b1be6fd31f
							
						
					
				
			
			
				commit
				
					
						d93e6232e8
					
				
			
		
					 7 changed files with 98 additions and 21 deletions
				
			
		| 
						 | 
				
			
			@ -263,10 +263,6 @@ func pushUpdate(opts PushUpdateOptions) (repo *Repository, err error) {
 | 
			
		|||
		commits = ListToPushCommits(l)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	if opts.RefFullName == git.BranchPrefix+repo.DefaultBranch {
 | 
			
		||||
		UpdateRepoIndexer(repo)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	if err := CommitRepoAction(CommitRepoActionOptions{
 | 
			
		||||
		PusherName:  opts.PusherName,
 | 
			
		||||
		RepoOwnerID: owner.ID,
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -183,7 +183,8 @@ func DeleteRepoFile(repo *models.Repository, doer *models.User, opts *DeleteRepo
 | 
			
		|||
	if err = repo.GetOwner(); err != nil {
 | 
			
		||||
		return nil, fmt.Errorf("GetOwner: %v", err)
 | 
			
		||||
	}
 | 
			
		||||
	err = models.PushUpdate(
 | 
			
		||||
	err = PushUpdate(
 | 
			
		||||
		repo,
 | 
			
		||||
		opts.NewBranch,
 | 
			
		||||
		models.PushUpdateOptions{
 | 
			
		||||
			PusherID:     doer.ID,
 | 
			
		||||
| 
						 | 
				
			
			@ -199,8 +200,6 @@ func DeleteRepoFile(repo *models.Repository, doer *models.User, opts *DeleteRepo
 | 
			
		|||
		return nil, fmt.Errorf("PushUpdate: %v", err)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// FIXME: Should we UpdateRepoIndexer(repo) here?
 | 
			
		||||
 | 
			
		||||
	file, err := GetFileResponseFromCommit(repo, commit, opts.NewBranch, treePath)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -394,7 +394,8 @@ func CreateOrUpdateRepoFile(repo *models.Repository, doer *models.User, opts *Up
 | 
			
		|||
	if err = repo.GetOwner(); err != nil {
 | 
			
		||||
		return nil, fmt.Errorf("GetOwner: %v", err)
 | 
			
		||||
	}
 | 
			
		||||
	err = models.PushUpdate(
 | 
			
		||||
	err = PushUpdate(
 | 
			
		||||
		repo,
 | 
			
		||||
		opts.NewBranch,
 | 
			
		||||
		models.PushUpdateOptions{
 | 
			
		||||
			PusherID:     doer.ID,
 | 
			
		||||
| 
						 | 
				
			
			@ -409,7 +410,6 @@ func CreateOrUpdateRepoFile(repo *models.Repository, doer *models.User, opts *Up
 | 
			
		|||
	if err != nil {
 | 
			
		||||
		return nil, fmt.Errorf("PushUpdate: %v", err)
 | 
			
		||||
	}
 | 
			
		||||
	models.UpdateRepoIndexer(repo)
 | 
			
		||||
 | 
			
		||||
	commit, err = t.GetCommit(commitHash)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
| 
						 | 
				
			
			@ -422,3 +422,17 @@ func CreateOrUpdateRepoFile(repo *models.Repository, doer *models.User, opts *Up
 | 
			
		|||
	}
 | 
			
		||||
	return file, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// PushUpdate must be called for any push actions in order to
 | 
			
		||||
// generates necessary push action history feeds and other operations
 | 
			
		||||
func PushUpdate(repo *models.Repository, branch string, opts models.PushUpdateOptions) error {
 | 
			
		||||
	err := models.PushUpdate(branch, opts)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return fmt.Errorf("PushUpdate: %v", err)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	if opts.RefFullName == git.BranchPrefix+repo.DefaultBranch {
 | 
			
		||||
		models.UpdateRepoIndexer(repo)
 | 
			
		||||
	}
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -188,7 +188,8 @@ func UploadRepoFiles(repo *models.Repository, doer *models.User, opts *UploadRep
 | 
			
		|||
	if err = repo.GetOwner(); err != nil {
 | 
			
		||||
		return fmt.Errorf("GetOwner: %v", err)
 | 
			
		||||
	}
 | 
			
		||||
	err = models.PushUpdate(
 | 
			
		||||
	err = PushUpdate(
 | 
			
		||||
		repo,
 | 
			
		||||
		opts.NewBranch,
 | 
			
		||||
		models.PushUpdateOptions{
 | 
			
		||||
			PusherID:     doer.ID,
 | 
			
		||||
| 
						 | 
				
			
			@ -203,7 +204,6 @@ func UploadRepoFiles(repo *models.Repository, doer *models.User, opts *UploadRep
 | 
			
		|||
	if err != nil {
 | 
			
		||||
		return fmt.Errorf("PushUpdate: %v", err)
 | 
			
		||||
	}
 | 
			
		||||
	// FIXME: Should we models.UpdateRepoIndexer(repo) here?
 | 
			
		||||
 | 
			
		||||
	return models.DeleteUploads(uploads...)
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -15,6 +15,7 @@ import (
 | 
			
		|||
	"code.gitea.io/gitea/modules/git"
 | 
			
		||||
	"code.gitea.io/gitea/modules/log"
 | 
			
		||||
	"code.gitea.io/gitea/modules/private"
 | 
			
		||||
	"code.gitea.io/gitea/modules/repofiles"
 | 
			
		||||
	"code.gitea.io/gitea/modules/util"
 | 
			
		||||
 | 
			
		||||
	macaron "gopkg.in/macaron.v1"
 | 
			
		||||
| 
						 | 
				
			
			@ -117,7 +118,15 @@ func HookPostReceive(ctx *macaron.Context) {
 | 
			
		|||
	// or other less-standard refs spaces are ignored since there
 | 
			
		||||
	// may be a very large number of them).
 | 
			
		||||
	if strings.HasPrefix(refFullName, git.BranchPrefix) || strings.HasPrefix(refFullName, git.TagPrefix) {
 | 
			
		||||
		if err := models.PushUpdate(branch, models.PushUpdateOptions{
 | 
			
		||||
		repo, err := models.GetRepositoryByOwnerAndName(ownerName, repoName)
 | 
			
		||||
		if err != nil {
 | 
			
		||||
			log.Error("Failed to get repository: %s/%s Error: %v", ownerName, repoName, err)
 | 
			
		||||
			ctx.JSON(http.StatusInternalServerError, map[string]interface{}{
 | 
			
		||||
				"err": fmt.Sprintf("Failed to get repository: %s/%s Error: %v", ownerName, repoName, err),
 | 
			
		||||
			})
 | 
			
		||||
			return
 | 
			
		||||
		}
 | 
			
		||||
		if err := repofiles.PushUpdate(repo, branch, models.PushUpdateOptions{
 | 
			
		||||
			RefFullName:  refFullName,
 | 
			
		||||
			OldCommitID:  oldCommitID,
 | 
			
		||||
			NewCommitID:  newCommitID,
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										56
									
								
								routers/private/push_update.go
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								routers/private/push_update.go
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
				
			
			@ -0,0 +1,56 @@
 | 
			
		|||
// Copyright 2017 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 private
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"encoding/json"
 | 
			
		||||
	"strings"
 | 
			
		||||
 | 
			
		||||
	"code.gitea.io/gitea/models"
 | 
			
		||||
	"code.gitea.io/gitea/modules/git"
 | 
			
		||||
	"code.gitea.io/gitea/modules/log"
 | 
			
		||||
	"code.gitea.io/gitea/modules/repofiles"
 | 
			
		||||
 | 
			
		||||
	macaron "gopkg.in/macaron.v1"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// PushUpdate update public key updates
 | 
			
		||||
func PushUpdate(ctx *macaron.Context) {
 | 
			
		||||
	var opt models.PushUpdateOptions
 | 
			
		||||
	if err := json.NewDecoder(ctx.Req.Request.Body).Decode(&opt); err != nil {
 | 
			
		||||
		ctx.JSON(500, map[string]interface{}{
 | 
			
		||||
			"err": err.Error(),
 | 
			
		||||
		})
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	branch := strings.TrimPrefix(opt.RefFullName, git.BranchPrefix)
 | 
			
		||||
	if len(branch) == 0 || opt.PusherID <= 0 {
 | 
			
		||||
		ctx.Error(404)
 | 
			
		||||
		log.Trace("PushUpdate: branch or secret is empty, or pusher ID is not valid")
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	repo, err := models.GetRepositoryByOwnerAndName(opt.RepoUserName, opt.RepoName)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.JSON(500, map[string]interface{}{
 | 
			
		||||
			"err": err.Error(),
 | 
			
		||||
		})
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	err = repofiles.PushUpdate(repo, branch, opt)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		if models.IsErrUserNotExist(err) {
 | 
			
		||||
			ctx.Error(404)
 | 
			
		||||
		} else {
 | 
			
		||||
			ctx.JSON(500, map[string]interface{}{
 | 
			
		||||
				"err": err.Error(),
 | 
			
		||||
			})
 | 
			
		||||
		}
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	ctx.Status(202)
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			@ -131,15 +131,18 @@ func deleteBranch(ctx *context.Context, branchName string) error {
 | 
			
		|||
	}
 | 
			
		||||
 | 
			
		||||
	// Don't return error below this
 | 
			
		||||
	if err := models.PushUpdate(branchName, models.PushUpdateOptions{
 | 
			
		||||
		RefFullName:  git.BranchPrefix + branchName,
 | 
			
		||||
		OldCommitID:  commit.ID.String(),
 | 
			
		||||
		NewCommitID:  git.EmptySHA,
 | 
			
		||||
		PusherID:     ctx.User.ID,
 | 
			
		||||
		PusherName:   ctx.User.Name,
 | 
			
		||||
		RepoUserName: ctx.Repo.Owner.Name,
 | 
			
		||||
		RepoName:     ctx.Repo.Repository.Name,
 | 
			
		||||
	}); err != nil {
 | 
			
		||||
	if err := repofiles.PushUpdate(
 | 
			
		||||
		ctx.Repo.Repository,
 | 
			
		||||
		branchName,
 | 
			
		||||
		models.PushUpdateOptions{
 | 
			
		||||
			RefFullName:  git.BranchPrefix + branchName,
 | 
			
		||||
			OldCommitID:  commit.ID.String(),
 | 
			
		||||
			NewCommitID:  git.EmptySHA,
 | 
			
		||||
			PusherID:     ctx.User.ID,
 | 
			
		||||
			PusherName:   ctx.User.Name,
 | 
			
		||||
			RepoUserName: ctx.Repo.Owner.Name,
 | 
			
		||||
			RepoName:     ctx.Repo.Repository.Name,
 | 
			
		||||
		}); err != nil {
 | 
			
		||||
		log.Error("Update: %v", err)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue