2020-09-08 23:45:10 +08:00
// Copyright 2019 The Gitea 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 setting
import (
"encoding/base64"
"os"
"path/filepath"
"time"
"code.gitea.io/gitea/modules/generate"
"code.gitea.io/gitea/modules/git"
"code.gitea.io/gitea/modules/log"
2020-11-28 02:42:08 +00:00
"code.gitea.io/gitea/modules/util"
2020-09-08 23:45:10 +08:00
ini "gopkg.in/ini.v1"
)
// LFS represents the configuration for Git LFS
var LFS = struct {
StartServer bool ` ini:"LFS_START_SERVER" `
JWTSecretBase64 string ` ini:"LFS_JWT_SECRET" `
JWTSecretBytes [ ] byte ` ini:"-" `
HTTPAuthExpiry time . Duration ` ini:"LFS_HTTP_AUTH_EXPIRY" `
MaxFileSize int64 ` ini:"LFS_MAX_FILE_SIZE" `
LocksPagingNum int ` ini:"LFS_LOCKS_PAGING_NUM" `
2020-09-29 17:05:13 +08:00
Storage
} { }
2020-09-08 23:45:10 +08:00
func newLFSService ( ) {
sec := Cfg . Section ( "server" )
if err := sec . MapTo ( & LFS ) ; err != nil {
log . Fatal ( "Failed to map LFS settings: %v" , err )
}
2020-09-29 17:05:13 +08:00
lfsSec := Cfg . Section ( "lfs" )
2020-10-13 04:58:34 +01:00
storageType := lfsSec . Key ( "STORAGE_TYPE" ) . MustString ( "" )
2020-09-29 17:05:13 +08:00
2020-10-13 04:58:34 +01:00
// Specifically default PATH to LFS_CONTENT_PATH
lfsSec . Key ( "PATH" ) . MustString (
sec . Key ( "LFS_CONTENT_PATH" ) . String ( ) )
2020-09-29 17:05:13 +08:00
2020-10-13 04:58:34 +01:00
LFS . Storage = getStorage ( "lfs" , storageType , lfsSec )
2020-09-29 17:05:13 +08:00
2020-10-13 04:58:34 +01:00
// Rest of LFS service settings
2020-09-08 23:45:10 +08:00
if LFS . LocksPagingNum == 0 {
LFS . LocksPagingNum = 50
}
LFS . HTTPAuthExpiry = sec . Key ( "LFS_HTTP_AUTH_EXPIRY" ) . MustDuration ( 20 * time . Minute )
if LFS . StartServer {
LFS . JWTSecretBytes = make ( [ ] byte , 32 )
n , err := base64 . RawURLEncoding . Decode ( LFS . JWTSecretBytes , [ ] byte ( LFS . JWTSecretBase64 ) )
if err != nil || n != 32 {
LFS . JWTSecretBase64 , err = generate . NewJwtSecret ( )
if err != nil {
log . Fatal ( "Error generating JWT Secret for custom config: %v" , err )
return
}
// Save secret
cfg := ini . Empty ( )
2020-11-28 02:42:08 +00:00
isFile , err := util . IsFile ( CustomConf )
if err != nil {
log . Error ( "Unable to check if %s is a file. Error: %v" , CustomConf , err )
}
if isFile {
2020-09-08 23:45:10 +08:00
// Keeps custom settings if there is already something.
if err := cfg . Append ( CustomConf ) ; err != nil {
log . Error ( "Failed to load custom conf '%s': %v" , CustomConf , err )
}
}
cfg . Section ( "server" ) . Key ( "LFS_JWT_SECRET" ) . SetValue ( LFS . JWTSecretBase64 )
if err := os . MkdirAll ( filepath . Dir ( CustomConf ) , os . ModePerm ) ; err != nil {
log . Fatal ( "Failed to create '%s': %v" , CustomConf , err )
}
if err := cfg . SaveTo ( CustomConf ) ; err != nil {
log . Fatal ( "Error saving generated JWT Secret to custom config: %v" , err )
return
}
}
}
}
// 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
err := git . LoadGitVersion ( )
if err != nil {
log . Fatal ( "Error retrieving git version: %v" , err )
}
2020-10-21 16:42:08 +01:00
if git . CheckGitVersionAtLeast ( "2.1.2" ) != nil {
2020-09-08 23:45:10 +08:00
LFS . StartServer = false
log . Error ( "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=" )
}
}
}