2020-09-08 18:45:10 +03:00
// Copyright 2019 The Gitea Authors. All rights reserved.
2022-11-27 21:20:29 +03:00
// SPDX-License-Identifier: MIT
2020-09-08 18:45:10 +03:00
package setting
import (
2023-06-14 06:42:38 +03:00
"fmt"
2020-09-08 18:45:10 +03:00
"time"
"code.gitea.io/gitea/modules/generate"
)
// LFS represents the configuration for Git LFS
var LFS = struct {
2024-02-18 20:39:04 +03:00
StartServer bool ` ini:"LFS_START_SERVER" `
2024-09-27 17:27:37 +03:00
AllowPureSSH bool ` ini:"LFS_ALLOW_PURE_SSH" `
2024-02-18 20:39:04 +03:00
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-08 18:45:10 +03:00
2023-06-14 06:42:38 +03:00
Storage * Storage
2020-09-29 12:05:13 +03:00
} { }
2020-09-08 18:45:10 +03:00
2023-06-14 06:42:38 +03:00
func loadLFSFrom ( rootCfg ConfigProvider ) error {
2023-02-19 19:12:01 +03:00
sec := rootCfg . Section ( "server" )
2020-09-08 18:45:10 +03:00
if err := sec . MapTo ( & LFS ) ; err != nil {
2023-06-14 06:42:38 +03:00
return fmt . Errorf ( "failed to map LFS settings: %v" , err )
2020-09-08 18:45:10 +03:00
}
2023-06-14 06:42:38 +03:00
lfsSec , _ := rootCfg . GetSection ( "lfs" )
2020-09-29 12:05:13 +03:00
2020-10-13 06:58:34 +03:00
// Specifically default PATH to LFS_CONTENT_PATH
2023-02-21 01:18:26 +03:00
// DEPRECATED should not be removed because users maybe upgrade from lower version to the latest version
// if these are removed, the warning will not be shown
2023-07-26 06:53:37 +03:00
deprecatedSetting ( rootCfg , "server" , "LFS_CONTENT_PATH" , "lfs" , "PATH" , "v1.19.0" )
if val := sec . Key ( "LFS_CONTENT_PATH" ) . String ( ) ; val != "" {
if lfsSec == nil {
lfsSec = rootCfg . Section ( "lfs" )
}
lfsSec . Key ( "PATH" ) . MustString ( val )
}
2020-09-29 12:05:13 +03:00
2023-06-14 06:42:38 +03:00
var err error
LFS . Storage , err = getStorage ( rootCfg , "lfs" , "" , lfsSec )
if err != nil {
return err
}
2020-09-29 12:05:13 +03:00
2020-10-13 06:58:34 +03:00
// Rest of LFS service settings
2020-09-08 18:45:10 +03:00
if LFS . LocksPagingNum == 0 {
LFS . LocksPagingNum = 50
}
2023-05-10 17:23:47 +03:00
LFS . HTTPAuthExpiry = sec . Key ( "LFS_HTTP_AUTH_EXPIRY" ) . MustDuration ( 24 * time . Hour )
2020-09-08 18:45:10 +03:00
2023-08-14 13:30:16 +03:00
if ! LFS . StartServer || ! InstallLock {
2023-06-14 06:42:38 +03:00
return nil
}
2024-02-18 20:39:04 +03:00
jwtSecretBase64 := loadSecret ( rootCfg . Section ( "server" ) , "LFS_JWT_SECRET_URI" , "LFS_JWT_SECRET" )
LFS . JWTSecretBytes , err = generate . DecodeJwtSecretBase64 ( jwtSecretBase64 )
2023-08-14 13:30:16 +03:00
if err != nil {
2024-02-18 20:39:04 +03:00
LFS . JWTSecretBytes , jwtSecretBase64 , err = generate . NewJwtSecretWithBase64 ( )
2023-06-14 06:42:38 +03:00
if err != nil {
2023-06-21 05:31:40 +03:00
return fmt . Errorf ( "error generating JWT Secret for custom config: %v" , err )
2023-06-14 06:42:38 +03:00
}
// Save secret
2023-06-21 05:31:40 +03:00
saveCfg , err := rootCfg . PrepareSaving ( )
if err != nil {
return fmt . Errorf ( "error saving JWT Secret for custom config: %v" , err )
}
2024-02-18 20:39:04 +03:00
rootCfg . Section ( "server" ) . Key ( "LFS_JWT_SECRET" ) . SetValue ( jwtSecretBase64 )
saveCfg . Section ( "server" ) . Key ( "LFS_JWT_SECRET" ) . SetValue ( jwtSecretBase64 )
2023-06-21 05:31:40 +03:00
if err := saveCfg . Save ( ) ; err != nil {
return fmt . Errorf ( "error saving JWT Secret for custom config: %v" , err )
2020-09-08 18:45:10 +03:00
}
}
2023-06-14 06:42:38 +03:00
return nil
2020-09-08 18:45:10 +03:00
}