githaven/update.go

83 lines
2.0 KiB
Go
Raw Normal View History

2014-03-16 06:53:41 +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-03-16 04:18:34 +00:00
package main
2014-03-25 16:00:36 +00:00
import (
"os"
"github.com/codegangsta/cli"
2014-03-25 16:05:09 +00:00
//"github.com/gogits/gogs/modules/log"
"github.com/qiniu/log"
2014-03-25 16:00:36 +00:00
)
2014-03-16 04:18:34 +00:00
var CmdUpdate = cli.Command{
Name: "update",
Usage: "This command just should be called by ssh shell",
Description: `
gogs serv provide access auth for repositories`,
Action: runUpdate,
Flags: []cli.Flag{},
}
2014-03-18 13:58:58 +00:00
// for command: ./gogs update
2014-03-25 16:00:36 +00:00
func runUpdate(c *cli.Context) {
2014-03-25 16:05:09 +00:00
//level := "0"
//os.MkdirAll("log", os.ModePerm)
//log.NewLogger(10000, "file", fmt.Sprintf(`{"level":%s,"filename":"%s"}`, level, "log/serv.log"))
//log.Info("start update logging...")
2014-03-23 08:31:13 +00:00
2014-03-25 16:05:09 +00:00
w, _ := os.Create("update.log")
defer w.Close()
log.SetOutput(w)
2014-03-25 16:00:36 +00:00
for i, arg := range c.Args() {
2014-03-25 16:05:09 +00:00
log.Info(i, arg)
}
2014-03-25 16:16:13 +00:00
userName := os.Getenv("userName")
//userId := os.Getenv("userId")
//repoId := os.Getenv("repoId")
//repoName := os.Getenv("repoName")
2014-03-16 04:18:34 +00:00
2014-03-25 16:16:13 +00:00
log.Info("username", userName)
/*f := models.RepoPath(userName, repoName)
2014-03-16 04:18:34 +00:00
repo, err := git.OpenRepository(f)
if err != nil {
2014-03-23 08:31:13 +00:00
log.Error("runUpdate.Open repoId: %v", err)
2014-03-16 04:18:34 +00:00
return
}
ref, err := repo.LookupReference("HEAD")
if err != nil {
2014-03-23 08:31:13 +00:00
log.Error("runUpdate.Ref repoId: %v", err)
2014-03-16 04:18:34 +00:00
return
}
lastCommit, err := repo.LookupCommit(ref.Oid)
if err != nil {
2014-03-23 08:31:13 +00:00
log.Error("runUpdate.Commit repoId: %v", err)
2014-03-16 04:18:34 +00:00
return
}
2014-03-16 15:02:59 +00:00
2014-03-16 06:53:41 +00:00
sUserId, err := strconv.Atoi(userId)
2014-03-16 04:18:34 +00:00
if err != nil {
2014-03-16 06:53:41 +00:00
log.Error("runUpdate.Parse userId: %v", err)
return
}
sRepoId, err := strconv.Atoi(repoId)
if err != nil {
log.Error("runUpdate.Parse repoId: %v", err)
return
}
2014-03-16 15:02:59 +00:00
commits := make([][]string, 0)
commits = append(commits, []string{lastCommit.Id().String(), lastCommit.Message()})
2014-03-16 06:53:41 +00:00
if err = models.CommitRepoAction(int64(sUserId), userName,
2014-03-16 15:02:59 +00:00
int64(sRepoId), repoName, commits); err != nil {
2014-03-16 06:53:41 +00:00
log.Error("runUpdate.models.CommitRepoAction: %v", err)
2014-03-23 08:31:13 +00:00
} else {
l := exec.Command("exec", "git", "update-server-info")
l.Run()
}*/
2014-03-16 04:18:34 +00:00
}