You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

lfs.go 2.4KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. // Copyright 2019 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package setting
  4. import (
  5. "encoding/base64"
  6. "fmt"
  7. "time"
  8. "code.gitea.io/gitea/modules/generate"
  9. )
  10. // LFS represents the configuration for Git LFS
  11. var LFS = struct {
  12. StartServer bool `ini:"LFS_START_SERVER"`
  13. JWTSecretBase64 string `ini:"LFS_JWT_SECRET"`
  14. JWTSecretBytes []byte `ini:"-"`
  15. HTTPAuthExpiry time.Duration `ini:"LFS_HTTP_AUTH_EXPIRY"`
  16. MaxFileSize int64 `ini:"LFS_MAX_FILE_SIZE"`
  17. LocksPagingNum int `ini:"LFS_LOCKS_PAGING_NUM"`
  18. Storage *Storage
  19. }{}
  20. func loadLFSFrom(rootCfg ConfigProvider) error {
  21. sec := rootCfg.Section("server")
  22. if err := sec.MapTo(&LFS); err != nil {
  23. return fmt.Errorf("failed to map LFS settings: %v", err)
  24. }
  25. lfsSec, _ := rootCfg.GetSection("lfs")
  26. // Specifically default PATH to LFS_CONTENT_PATH
  27. // DEPRECATED should not be removed because users maybe upgrade from lower version to the latest version
  28. // if these are removed, the warning will not be shown
  29. deprecatedSetting(rootCfg, "server", "LFS_CONTENT_PATH", "lfs", "PATH", "v1.19.0")
  30. if val := sec.Key("LFS_CONTENT_PATH").String(); val != "" {
  31. if lfsSec == nil {
  32. lfsSec = rootCfg.Section("lfs")
  33. }
  34. lfsSec.Key("PATH").MustString(val)
  35. }
  36. var err error
  37. LFS.Storage, err = getStorage(rootCfg, "lfs", "", lfsSec)
  38. if err != nil {
  39. return err
  40. }
  41. // Rest of LFS service settings
  42. if LFS.LocksPagingNum == 0 {
  43. LFS.LocksPagingNum = 50
  44. }
  45. LFS.HTTPAuthExpiry = sec.Key("LFS_HTTP_AUTH_EXPIRY").MustDuration(24 * time.Hour)
  46. if !LFS.StartServer {
  47. return nil
  48. }
  49. LFS.JWTSecretBytes = make([]byte, 32)
  50. n, err := base64.RawURLEncoding.Decode(LFS.JWTSecretBytes, []byte(LFS.JWTSecretBase64))
  51. if (err != nil || n != 32) && InstallLock {
  52. LFS.JWTSecretBase64, err = generate.NewJwtSecretBase64()
  53. if err != nil {
  54. return fmt.Errorf("error generating JWT Secret for custom config: %v", err)
  55. }
  56. // Save secret
  57. saveCfg, err := rootCfg.PrepareSaving()
  58. if err != nil {
  59. return fmt.Errorf("error saving JWT Secret for custom config: %v", err)
  60. }
  61. rootCfg.Section("server").Key("LFS_JWT_SECRET").SetValue(LFS.JWTSecretBase64)
  62. saveCfg.Section("server").Key("LFS_JWT_SECRET").SetValue(LFS.JWTSecretBase64)
  63. if err := saveCfg.Save(); err != nil {
  64. return fmt.Errorf("error saving JWT Secret for custom config: %v", err)
  65. }
  66. }
  67. return nil
  68. }