Move push update to post-receive and protected branch check to pre-receive (#1030)
* move all push update to git hook post-receive and protected branch check to git hook pre-receive * add SSH_ORIGINAL_COMMAND check back * remove all unused codes * fix the importtokarchuk/v1.17
parent
e8e56da9ac
commit
cd1821a7e2
@ -1,83 +0,0 @@ |
|||||||
// 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 cmd |
|
||||||
|
|
||||||
import ( |
|
||||||
"os" |
|
||||||
"strconv" |
|
||||||
"strings" |
|
||||||
|
|
||||||
"github.com/urfave/cli" |
|
||||||
|
|
||||||
"code.gitea.io/git" |
|
||||||
"code.gitea.io/gitea/models" |
|
||||||
"code.gitea.io/gitea/modules/log" |
|
||||||
"code.gitea.io/gitea/modules/setting" |
|
||||||
) |
|
||||||
|
|
||||||
// CmdUpdate represents the available update sub-command.
|
|
||||||
var CmdUpdate = cli.Command{ |
|
||||||
Name: "update", |
|
||||||
Usage: "This command should only be called by Git hook", |
|
||||||
Description: `Update get pushed info and insert into database`, |
|
||||||
Action: runUpdate, |
|
||||||
Flags: []cli.Flag{ |
|
||||||
cli.StringFlag{ |
|
||||||
Name: "config, c", |
|
||||||
Value: "custom/conf/app.ini", |
|
||||||
Usage: "Custom configuration file path", |
|
||||||
}, |
|
||||||
}, |
|
||||||
} |
|
||||||
|
|
||||||
func runUpdate(c *cli.Context) error { |
|
||||||
if c.IsSet("config") { |
|
||||||
setting.CustomConf = c.String("config") |
|
||||||
} |
|
||||||
|
|
||||||
setup("update.log") |
|
||||||
|
|
||||||
if len(os.Getenv("SSH_ORIGINAL_COMMAND")) == 0 { |
|
||||||
log.GitLogger.Trace("SSH_ORIGINAL_COMMAND is empty") |
|
||||||
return nil |
|
||||||
} |
|
||||||
|
|
||||||
args := c.Args() |
|
||||||
if len(args) != 3 { |
|
||||||
log.GitLogger.Fatal(2, "Arguments received are not equal to three") |
|
||||||
} else if len(args[0]) == 0 { |
|
||||||
log.GitLogger.Fatal(2, "First argument 'refName' is empty, shouldn't use") |
|
||||||
} |
|
||||||
|
|
||||||
// protected branch check
|
|
||||||
branchName := strings.TrimPrefix(args[0], git.BranchPrefix) |
|
||||||
repoID, _ := strconv.ParseInt(os.Getenv(models.ProtectedBranchRepoID), 10, 64) |
|
||||||
log.GitLogger.Trace("pushing to %d %v", repoID, branchName) |
|
||||||
accessMode := models.ParseAccessMode(os.Getenv(models.ProtectedBranchAccessMode)) |
|
||||||
// skip admin or owner AccessMode
|
|
||||||
if accessMode == models.AccessModeWrite { |
|
||||||
protectBranch, err := models.GetProtectedBranchBy(repoID, branchName) |
|
||||||
if err != nil { |
|
||||||
log.GitLogger.Fatal(2, "retrieve protected branches information failed") |
|
||||||
} |
|
||||||
|
|
||||||
if protectBranch != nil { |
|
||||||
log.GitLogger.Fatal(2, "protected branches can not be pushed to") |
|
||||||
} |
|
||||||
} |
|
||||||
|
|
||||||
task := models.UpdateTask{ |
|
||||||
UUID: os.Getenv("GITEA_UUID"), |
|
||||||
RefName: args[0], |
|
||||||
OldCommitID: args[1], |
|
||||||
NewCommitID: args[2], |
|
||||||
} |
|
||||||
|
|
||||||
if err := models.AddUpdateTask(&task); err != nil { |
|
||||||
log.GitLogger.Fatal(2, "AddUpdateTask: %v", err) |
|
||||||
} |
|
||||||
|
|
||||||
return nil |
|
||||||
} |
|
@ -1,20 +0,0 @@ |
|||||||
- |
|
||||||
id: 1 |
|
||||||
uuid: uuid1 |
|
||||||
ref_name: refName1 |
|
||||||
old_commit_id: oldCommitId1 |
|
||||||
new_commit_id: newCommitId1 |
|
||||||
|
|
||||||
- |
|
||||||
id: 2 |
|
||||||
uuid: uuid2 |
|
||||||
ref_name: refName2 |
|
||||||
old_commit_id: oldCommitId2 |
|
||||||
new_commit_id: newCommitId2 |
|
||||||
|
|
||||||
- |
|
||||||
id: 3 |
|
||||||
uuid: uuid3 |
|
||||||
ref_name: refName3 |
|
||||||
old_commit_id: oldCommitId3 |
|
||||||
new_commit_id: newCommitId3 |
|
Loading…
Reference in new issue