aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--cmd/hook.go12
-rw-r--r--cmd/serv.go22
-rw-r--r--integrations/integration_test.go1
-rw-r--r--modules/setting/setting.go42
-rw-r--r--routers/init.go1
5 files changed, 48 insertions, 30 deletions
diff --git a/cmd/hook.go b/cmd/hook.go
index 63cb605929..bde449ccdc 100644
--- a/cmd/hook.go
+++ b/cmd/hook.go
@@ -10,7 +10,6 @@ import (
"fmt"
"net/url"
"os"
- "path/filepath"
"strconv"
"strings"
@@ -63,11 +62,6 @@ var (
}
)
-func hookSetup(logPath string) {
- setting.NewContext()
- log.NewGitLogger(filepath.Join(setting.LogRootPath, logPath))
-}
-
func runHookPreReceive(c *cli.Context) error {
if len(os.Getenv("SSH_ORIGINAL_COMMAND")) == 0 {
return nil
@@ -79,7 +73,7 @@ func runHookPreReceive(c *cli.Context) error {
setting.CustomConf = c.GlobalString("config")
}
- hookSetup("hooks/pre-receive.log")
+ setup("hooks/pre-receive.log")
// the environment setted on serv command
repoID, _ := strconv.ParseInt(os.Getenv(models.ProtectedBranchRepoID), 10, 64)
@@ -155,7 +149,7 @@ func runHookUpdate(c *cli.Context) error {
setting.CustomConf = c.GlobalString("config")
}
- hookSetup("hooks/update.log")
+ setup("hooks/update.log")
return nil
}
@@ -171,7 +165,7 @@ func runHookPostReceive(c *cli.Context) error {
setting.CustomConf = c.GlobalString("config")
}
- hookSetup("hooks/post-receive.log")
+ setup("hooks/post-receive.log")
// the environment setted on serv command
repoID, _ := strconv.ParseInt(os.Getenv(models.ProtectedBranchRepoID), 10, 64)
diff --git a/cmd/serv.go b/cmd/serv.go
index c98228745d..ec2258412f 100644
--- a/cmd/serv.go
+++ b/cmd/serv.go
@@ -14,6 +14,7 @@ import (
"strings"
"time"
+ "code.gitea.io/git"
"code.gitea.io/gitea/models"
"code.gitea.io/gitea/modules/log"
"code.gitea.io/gitea/modules/pprof"
@@ -22,6 +23,7 @@ import (
"github.com/Unknwon/com"
"github.com/dgrijalva/jwt-go"
+ version "github.com/mcuadros/go-version"
"github.com/urfave/cli"
)
@@ -48,8 +50,28 @@ var CmdServ = cli.Command{
},
}
+func checkLFSVersion() {
+ if setting.LFS.StartServer {
+ //Disable LFS client hooks if installed for the current OS user
+ //Needs at least git v2.1.2
+ binVersion, err := git.BinVersion()
+ if err != nil {
+ fail(fmt.Sprintf("Error retrieving git version: %v", err), fmt.Sprintf("Error retrieving git version: %v", err))
+ }
+
+ if !version.Compare(binVersion, "2.1.2", ">=") {
+ setting.LFS.StartServer = false
+ println("LFS server support needs at least Git v2.1.2, disabled")
+ } else {
+ git.GlobalCommandArgs = append(git.GlobalCommandArgs, "-c", "filter.lfs.required=",
+ "-c", "filter.lfs.smudge=", "-c", "filter.lfs.clean=")
+ }
+ }
+}
+
func setup(logPath string) {
setting.NewContext()
+ checkLFSVersion()
log.NewGitLogger(filepath.Join(setting.LogRootPath, logPath))
}
diff --git a/integrations/integration_test.go b/integrations/integration_test.go
index 25f6cff27c..ba3c7e3071 100644
--- a/integrations/integration_test.go
+++ b/integrations/integration_test.go
@@ -99,6 +99,7 @@ func initIntegrationTest() {
}
setting.NewContext()
+ setting.CheckLFSVersion()
models.LoadConfigs()
switch {
diff --git a/modules/setting/setting.go b/modules/setting/setting.go
index c10f165c8e..23304453d2 100644
--- a/modules/setting/setting.go
+++ b/modules/setting/setting.go
@@ -693,6 +693,27 @@ func createPIDFile(pidPath string) {
}
}
+// CheckLFSVersion will check lfs version, if not satisfied, then disable it.
+func CheckLFSVersion() {
+ if LFS.StartServer {
+ //Disable LFS client hooks if installed for the current OS user
+ //Needs at least git v2.1.2
+
+ binVersion, err := git.BinVersion()
+ if err != nil {
+ log.Fatal(4, "Error retrieving git version: %v", err)
+ }
+
+ if !version.Compare(binVersion, "2.1.2", ">=") {
+ LFS.StartServer = false
+ log.Error(4, "LFS server support needs at least Git v2.1.2")
+ } else {
+ git.GlobalCommandArgs = append(git.GlobalCommandArgs, "-c", "filter.lfs.required=",
+ "-c", "filter.lfs.smudge=", "-c", "filter.lfs.clean=")
+ }
+ }
+}
+
// NewContext initializes configuration context.
// NOTE: do not print any log except error.
func NewContext() {
@@ -888,7 +909,6 @@ func NewContext() {
LFS.HTTPAuthExpiry = sec.Key("LFS_HTTP_AUTH_EXPIRY").MustDuration(20 * time.Minute)
if LFS.StartServer {
-
if err := os.MkdirAll(LFS.ContentPath, 0700); err != nil {
log.Fatal(4, "Failed to create '%s': %v", LFS.ContentPath, err)
}
@@ -922,26 +942,6 @@ func NewContext() {
return
}
}
-
- //Disable LFS client hooks if installed for the current OS user
- //Needs at least git v2.1.2
-
- binVersion, err := git.BinVersion()
- if err != nil {
- log.Fatal(4, "Error retrieving git version: %v", err)
- }
-
- if !version.Compare(binVersion, "2.1.2", ">=") {
-
- LFS.StartServer = false
- log.Error(4, "LFS server support needs at least Git v2.1.2")
-
- } else {
-
- git.GlobalCommandArgs = append(git.GlobalCommandArgs, "-c", "filter.lfs.required=",
- "-c", "filter.lfs.smudge=", "-c", "filter.lfs.clean=")
-
- }
}
sec = Cfg.Section("security")
diff --git a/routers/init.go b/routers/init.go
index a52f9ca1b4..3152988ba4 100644
--- a/routers/init.go
+++ b/routers/init.go
@@ -45,6 +45,7 @@ func NewServices() {
// GlobalInit is for global configuration reload-able.
func GlobalInit() {
setting.NewContext()
+ setting.CheckLFSVersion()
log.Trace("AppPath: %s", setting.AppPath)
log.Trace("AppWorkPath: %s", setting.AppWorkPath)
log.Trace("Custom path: %s", setting.CustomPath)