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