mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 16:40:24 +08:00 
			
		
		
		
	fix lfs version check warning log when using ssh protocol (#5501)
This commit is contained in:
		
							
								
								
									
										12
									
								
								cmd/hook.go
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								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)
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										22
									
								
								cmd/serv.go
									
									
									
									
									
								
							
							
						
						
									
										22
									
								
								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))
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -99,6 +99,7 @@ func initIntegrationTest() {
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	setting.NewContext()
 | 
			
		||||
	setting.CheckLFSVersion()
 | 
			
		||||
	models.LoadConfigs()
 | 
			
		||||
 | 
			
		||||
	switch {
 | 
			
		||||
 
 | 
			
		||||
@@ -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")
 | 
			
		||||
 
 | 
			
		||||
@@ -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)
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user