forgejo/models/update.go

159 lines
3.8 KiB
Go
Raw Normal View History

2014-04-27 07:05:13 +00:00
// Copyright 2014 The Gogs Authors. All rights reserved.
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file.
2014-04-11 02:27:13 +00:00
package models
import (
"container/list"
2014-06-23 20:22:34 +00:00
"fmt"
2014-04-11 02:27:13 +00:00
"os/exec"
"strings"
"github.com/gogits/git-shell"
2014-06-20 05:14:54 +00:00
"github.com/gogits/gogs/modules/log"
2014-04-11 02:27:13 +00:00
)
2014-06-28 15:56:41 +00:00
type UpdateTask struct {
ID int64 `xorm:"pk autoincr"`
UUID string `xorm:"index"`
2014-06-28 15:56:41 +00:00
RefName string
OldCommitID string
NewCommitID string
2014-06-28 15:56:41 +00:00
}
func AddUpdateTask(task *UpdateTask) error {
_, err := x.Insert(task)
return err
}
2015-11-05 02:57:10 +00:00
// GetUpdateTaskByUUID returns update task by given UUID.
func GetUpdateTaskByUUID(uuid string) (*UpdateTask, error) {
2014-06-28 15:56:41 +00:00
task := &UpdateTask{
UUID: uuid,
2014-06-28 15:56:41 +00:00
}
has, err := x.Get(task)
2014-06-28 15:56:41 +00:00
if err != nil {
return nil, err
} else if !has {
2015-11-05 02:57:10 +00:00
return nil, ErrUpdateTaskNotExist{uuid}
2014-06-28 15:56:41 +00:00
}
return task, nil
2014-06-28 15:56:41 +00:00
}
func DeleteUpdateTaskByUUID(uuid string) error {
_, err := x.Delete(&UpdateTask{UUID: uuid})
2014-06-28 15:56:41 +00:00
return err
}
func ListToPushCommits(l *list.List) *PushCommits {
commits := make([]*PushCommit, 0)
var actEmail string
for e := l.Front(); e != nil; e = e.Next() {
commit := e.Value.(*git.Commit)
if actEmail == "" {
actEmail = commit.Committer.Email
}
commits = append(commits,
&PushCommit{commit.ID.String(),
commit.Message(),
commit.Author.Email,
commit.Author.Name,
})
}
return &PushCommits{l.Len(), commits, "", nil}
}
func Update(refName, oldCommitID, newCommitID, userName, repoUserName, repoName string, userID int64) error {
isNew := strings.HasPrefix(oldCommitID, "0000000")
2014-04-11 02:27:13 +00:00
if isNew &&
strings.HasPrefix(newCommitID, "0000000") {
2014-06-23 20:22:34 +00:00
return fmt.Errorf("old rev and new rev both 000000")
2014-04-11 02:27:13 +00:00
}
2014-05-03 05:37:49 +00:00
f := RepoPath(repoUserName, repoName)
2014-04-11 02:27:13 +00:00
gitUpdate := exec.Command("git", "update-server-info")
gitUpdate.Dir = f
gitUpdate.Run()
isDel := strings.HasPrefix(newCommitID, "0000000")
2014-05-03 03:12:15 +00:00
if isDel {
log.GitLogger.Info("del rev", refName, "from", userName+"/"+repoName+".git", "by", userID)
2014-06-23 20:22:34 +00:00
return nil
2014-05-03 03:12:15 +00:00
}
gitRepo, err := git.OpenRepository(f)
2014-04-11 02:27:13 +00:00
if err != nil {
2014-06-23 20:22:34 +00:00
return fmt.Errorf("runUpdate.Open repoId: %v", err)
2014-04-11 02:27:13 +00:00
}
user, err := GetUserByName(repoUserName)
2014-05-03 05:37:49 +00:00
if err != nil {
2014-06-23 20:22:34 +00:00
return fmt.Errorf("runUpdate.GetUserByName: %v", err)
2014-05-03 05:37:49 +00:00
}
repo, err := GetRepositoryByName(user.Id, repoName)
2014-04-11 02:27:13 +00:00
if err != nil {
2014-06-23 20:22:34 +00:00
return fmt.Errorf("runUpdate.GetRepositoryByName userId: %v", err)
2014-04-11 02:27:13 +00:00
}
2014-07-26 04:24:27 +00:00
// Push tags.
2014-06-28 06:55:33 +00:00
if strings.HasPrefix(refName, "refs/tags/") {
tagName := git.RefEndName(refName)
tag, err := gitRepo.GetTag(tagName)
2014-06-28 06:55:33 +00:00
if err != nil {
2014-07-26 04:24:27 +00:00
log.GitLogger.Fatal(4, "runUpdate.GetTag: %v", err)
2014-06-28 06:55:33 +00:00
}
var actEmail string
if tag.Tagger != nil {
actEmail = tag.Tagger.Email
} else {
cmt, err := tag.Commit()
if err != nil {
2014-07-26 04:24:27 +00:00
log.GitLogger.Fatal(4, "runUpdate.GetTag Commit: %v", err)
2014-06-28 06:55:33 +00:00
}
actEmail = cmt.Committer.Email
}
2015-11-13 22:10:25 +00:00
commit := &PushCommits{}
2014-06-28 06:55:33 +00:00
if err = CommitRepoAction(userID, user.Id, userName, actEmail,
repo.ID, repoUserName, repoName, refName, commit, oldCommitID, newCommitID); err != nil {
2014-10-11 01:40:51 +00:00
log.GitLogger.Fatal(4, "CommitRepoAction: %s/%s:%v", repoUserName, repoName, err)
2014-06-28 06:55:33 +00:00
}
2014-06-28 07:00:03 +00:00
return err
2014-06-28 06:55:33 +00:00
}
newCommit, err := gitRepo.GetCommit(newCommitID)
2014-06-28 15:56:41 +00:00
if err != nil {
return fmt.Errorf("runUpdate GetCommit of newCommitId: %v", err)
}
2014-10-11 01:40:51 +00:00
// Push new branch.
2014-06-28 15:56:41 +00:00
var l *list.List
if isNew {
l, err = newCommit.CommitsBefore()
if err != nil {
2015-10-23 14:31:13 +00:00
return fmt.Errorf("CommitsBefore: %v", err)
2014-06-28 15:56:41 +00:00
}
} else {
l, err = newCommit.CommitsBeforeUntil(oldCommitID)
2014-06-28 15:56:41 +00:00
if err != nil {
2015-10-23 14:31:13 +00:00
return fmt.Errorf("CommitsBeforeUntil: %v", err)
2014-06-28 15:56:41 +00:00
}
}
if err != nil {
return fmt.Errorf("runUpdate.Commit repoId: %v", err)
}
if err = CommitRepoAction(userID, user.Id, userName, user.Email,
repo.ID, repoUserName, repoName, refName, ListToPushCommits(l), oldCommitID, newCommitID); err != nil {
2014-06-23 20:22:34 +00:00
return fmt.Errorf("runUpdate.models.CommitRepoAction: %s/%s:%v", repoUserName, repoName, err)
2014-04-11 02:27:13 +00:00
}
2014-06-23 20:22:34 +00:00
return nil
2014-04-11 02:27:13 +00:00
}