summaryrefslogtreecommitdiffstats
path: root/update.go
blob: 7386d33215806fd6649509390c4188691da24c72 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
// 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.

package main

import (
"os"
"github.com/codegangsta/cli"
//"github.com/gogits/gogs/modules/log"
"github.com/qiniu/log"
)

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{},
}

// for command: ./gogs update
func runUpdate(c *cli.Context) {
	//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...")

	w, _ := os.Create("update.log")
	defer w.Close()

	log.SetOutput(w)
	for i, arg := range c.Args() {
		log.Info(i, arg)
	}
	userName := os.Getenv("userName")
	//userId := os.Getenv("userId")
	//repoId := os.Getenv("repoId")
	//repoName := os.Getenv("repoName")

	log.Info("username", userName)
	/*f := models.RepoPath(userName, repoName)

	repo, err := git.OpenRepository(f)
	if err != nil {
		log.Error("runUpdate.Open repoId: %v", err)
		return
	}

	ref, err := repo.LookupReference("HEAD")
	if err != nil {
		log.Error("runUpdate.Ref repoId: %v", err)
		return
	}

	lastCommit, err := repo.LookupCommit(ref.Oid)
	if err != nil {
		log.Error("runUpdate.Commit repoId: %v", err)
		return
	}

	sUserId, err := strconv.Atoi(userId)
	if err != nil {
		log.Error("runUpdate.Parse userId: %v", err)
		return
	}
	sRepoId, err := strconv.Atoi(repoId)
	if err != nil {
		log.Error("runUpdate.Parse repoId: %v", err)
		return
	}
	commits := make([][]string, 0)
	commits = append(commits, []string{lastCommit.Id().String(), lastCommit.Message()})
	if err = models.CommitRepoAction(int64(sUserId), userName,
		int64(sRepoId), repoName, commits); err != nil {
		log.Error("runUpdate.models.CommitRepoAction: %v", err)
	} else {
		l := exec.Command("exec", "git", "update-server-info")
		l.Run()
	}*/
}