diff options
author | Lunny Xiao <xiaolunwen@gmail.com> | 2014-04-11 10:27:13 +0800 |
---|---|---|
committer | Lunny Xiao <xiaolunwen@gmail.com> | 2014-04-11 10:27:13 +0800 |
commit | db39e58a139ef8581b4b61d2d4a68b4e5324acdf (patch) | |
tree | 7c73c2b6fa71ec1a970fe17f67e10af49e6ec9c9 /update.go | |
parent | 8faa0dbcd77ec17bbf88041f46e2fc48f6ca6f31 (diff) | |
download | gitea-db39e58a139ef8581b4b61d2d4a68b4e5324acdf.tar.gz gitea-db39e58a139ef8581b4b61d2d4a68b4e5324acdf.zip |
add actions for http push
Diffstat (limited to 'update.go')
-rw-r--r-- | update.go | 122 |
1 files changed, 21 insertions, 101 deletions
@@ -5,19 +5,14 @@ package main import ( - "container/list" "os" - "os/exec" "path" "strconv" - "strings" "github.com/codegangsta/cli" - qlog "github.com/qiniu/log" - - "github.com/gogits/git" "github.com/gogits/gogs/models" "github.com/gogits/gogs/modules/base" + qlog "github.com/qiniu/log" ) var CmdUpdate = cli.Command{ @@ -42,100 +37,20 @@ func newUpdateLogger(execDir string) { qlog.Info("Start logging update...") } -func update(refName, oldCommitId, newCommitId string) { - isNew := strings.HasPrefix(oldCommitId, "0000000") - if isNew && - strings.HasPrefix(newCommitId, "0000000") { - qlog.Fatal("old rev and new rev both 000000") - } - - userName := os.Getenv("userName") - userId := os.Getenv("userId") - //repoId := os.Getenv("repoId") - repoName := os.Getenv("repoName") - - f := models.RepoPath(userName, repoName) - - gitUpdate := exec.Command("git", "update-server-info") - gitUpdate.Dir = f - gitUpdate.Run() - - repo, err := git.OpenRepository(f) - if err != nil { - qlog.Fatalf("runUpdate.Open repoId: %v", err) - } - - newOid, err := git.NewOidFromString(newCommitId) - if err != nil { - qlog.Fatalf("runUpdate.Ref repoId: %v", err) - } - - newCommit, err := repo.LookupCommit(newOid) - if err != nil { - qlog.Fatalf("runUpdate.Ref repoId: %v", err) - } - - var l *list.List - // if a new branch - if isNew { - l, err = repo.CommitsBefore(newCommit.Id()) - if err != nil { - qlog.Fatalf("Find CommitsBefore erro:", err) - } - } else { - oldOid, err := git.NewOidFromString(oldCommitId) - if err != nil { - qlog.Fatalf("runUpdate.Ref repoId: %v", err) - } - - oldCommit, err := repo.LookupCommit(oldOid) - if err != nil { - qlog.Fatalf("runUpdate.Ref repoId: %v", err) - } - l = repo.CommitsBetween(newCommit, oldCommit) - } - - if err != nil { - qlog.Fatalf("runUpdate.Commit repoId: %v", err) - } - - sUserId, err := strconv.Atoi(userId) - if err != nil { - qlog.Fatalf("runUpdate.Parse userId: %v", err) - } - - repos, err := models.GetRepositoryByName(int64(sUserId), repoName) - if err != nil { - qlog.Fatalf("runUpdate.GetRepositoryByName userId: %v", err) - } - - commits := make([]*base.PushCommit, 0) - var maxCommits = 3 - 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, - &base.PushCommit{commit.Id().String(), - commit.Message(), - commit.Author.Email, - commit.Author.Name}) - if len(commits) >= maxCommits { - break - } - } - - //commits = append(commits, []string{lastCommit.Id().String(), lastCommit.Message()}) - if err = models.CommitRepoAction(int64(sUserId), userName, actEmail, - repos.Id, repoName, git.BranchName(refName), &base.PushCommits{l.Len(), commits}); err != nil { - qlog.Fatalf("runUpdate.models.CommitRepoAction: %v", err) - } +func updateEnv(refName, oldCommitId, newCommitId string) { + os.Setenv("refName", refName) + os.Setenv("oldCommitId", oldCommitId) + os.Setenv("newCommitId", newCommitId) + qlog.Error("set envs:", refName, oldCommitId, newCommitId) } // for command: ./gogs update func runUpdate(c *cli.Context) { + cmd := os.Getenv("SSH_ORIGINAL_COMMAND") + if cmd == "" { + return + } + execDir, _ := base.ExecDir() newUpdateLogger(execDir) @@ -153,12 +68,17 @@ func runUpdate(c *cli.Context) { qlog.Fatal("received less 3 parameters") } - refName := args[0] - if refName == "" { + if args[0] == "" { qlog.Fatal("refName is empty, shouldn't use") } - oldCommitId := args[1] - newCommitId := args[2] - update(refName, oldCommitId, newCommitId) + //updateEnv(args[0], args[1], args[2]) + + userName := os.Getenv("userName") + userId := os.Getenv("userId") + iUserId, _ := strconv.ParseInt(userId, 10, 64) + //repoId := os.Getenv("repoId") + repoName := os.Getenv("repoName") + + models.Update(args[0], args[1], args[2], userName, repoName, iUserId) } |