summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLunny Xiao <xiaolunwen@gmail.com>2023-01-08 21:22:41 +0800
committerGitHub <noreply@github.com>2023-01-08 21:22:41 +0800
commitdfd2db569594006fc7e9ba7a0eb3f796f70e4fda (patch)
treebf7cc0c227cb50d0be1772806a769670acaf063f
parentbdf8c80f4196763869b540554656dcadacb8d9bf (diff)
downloadgitea-dfd2db569594006fc7e9ba7a0eb3f796f70e4fda.tar.gz
gitea-dfd2db569594006fc7e9ba7a0eb3f796f70e4fda.zip
Fix set system setting failure once it cached (#22333)
Unfortunately, #22295 introduced a bug that when set a cached system setting, it will not affect. This PR make sure to remove the cache key when updating a system setting. Fix #22332
-rw-r--r--models/system/setting.go27
-rw-r--r--models/system/setting_test.go6
2 files changed, 20 insertions, 13 deletions
diff --git a/models/system/setting.go b/models/system/setting.go
index 3eb8b3955d..0701c4bf48 100644
--- a/models/system/setting.go
+++ b/models/system/setting.go
@@ -12,7 +12,7 @@ import (
"code.gitea.io/gitea/models/db"
"code.gitea.io/gitea/modules/cache"
- "code.gitea.io/gitea/modules/setting"
+ setting_module "code.gitea.io/gitea/modules/setting"
"code.gitea.io/gitea/modules/timeutil"
"strk.kbt.io/projects/go/libravatar"
@@ -88,7 +88,7 @@ func GetSettingNoCache(key string) (*Setting, error) {
if len(v) == 0 {
return nil, ErrSettingIsNotExist{key}
}
- return v[key], nil
+ return v[strings.ToLower(key)], nil
}
// GetSetting returns the setting value via the key
@@ -131,7 +131,7 @@ func GetSettings(keys []string) (map[string]*Setting, error) {
type AllSettings map[string]*Setting
func (settings AllSettings) Get(key string) Setting {
- if v, ok := settings[key]; ok {
+ if v, ok := settings[strings.ToLower(key)]; ok {
return *v
}
return Setting{}
@@ -184,14 +184,17 @@ func SetSettingNoVersion(key, value string) error {
// SetSetting updates a users' setting for a specific key
func SetSetting(setting *Setting) error {
- _, err := cache.GetString(genSettingCacheKey(setting.SettingKey), func() (string, error) {
- return setting.SettingValue, upsertSettingValue(strings.ToLower(setting.SettingKey), setting.SettingValue, setting.Version)
- })
- if err != nil {
+ if err := upsertSettingValue(strings.ToLower(setting.SettingKey), setting.SettingValue, setting.Version); err != nil {
return err
}
setting.Version++
+
+ cc := cache.GetCache()
+ if cc != nil {
+ return cc.Put(genSettingCacheKey(setting.SettingKey), setting.SettingValue, setting_module.CacheService.TTLSeconds())
+ }
+
return nil
}
@@ -243,7 +246,7 @@ func Init() error {
var disableGravatar bool
disableGravatarSetting, err := GetSettingNoCache(KeyPictureDisableGravatar)
if IsErrSettingIsNotExist(err) {
- disableGravatar = setting.GetDefaultDisableGravatar()
+ disableGravatar = setting_module.GetDefaultDisableGravatar()
disableGravatarSetting = &Setting{SettingValue: strconv.FormatBool(disableGravatar)}
} else if err != nil {
return err
@@ -254,7 +257,7 @@ func Init() error {
var enableFederatedAvatar bool
enableFederatedAvatarSetting, err := GetSettingNoCache(KeyPictureEnableFederatedAvatar)
if IsErrSettingIsNotExist(err) {
- enableFederatedAvatar = setting.GetDefaultEnableFederatedAvatar(disableGravatar)
+ enableFederatedAvatar = setting_module.GetDefaultEnableFederatedAvatar(disableGravatar)
enableFederatedAvatarSetting = &Setting{SettingValue: strconv.FormatBool(enableFederatedAvatar)}
} else if err != nil {
return err
@@ -262,16 +265,16 @@ func Init() error {
enableFederatedAvatar = disableGravatarSetting.GetValueBool()
}
- if setting.OfflineMode {
+ if setting_module.OfflineMode {
disableGravatar = true
enableFederatedAvatar = false
}
if enableFederatedAvatar || !disableGravatar {
var err error
- GravatarSourceURL, err = url.Parse(setting.GravatarSource)
+ GravatarSourceURL, err = url.Parse(setting_module.GravatarSource)
if err != nil {
- return fmt.Errorf("Failed to parse Gravatar URL(%s): %w", setting.GravatarSource, err)
+ return fmt.Errorf("Failed to parse Gravatar URL(%s): %w", setting_module.GravatarSource, err)
}
}
diff --git a/models/system/setting_test.go b/models/system/setting_test.go
index 3ff5ba2520..c43d2e3084 100644
--- a/models/system/setting_test.go
+++ b/models/system/setting_test.go
@@ -33,10 +33,14 @@ func TestSettings(t *testing.T) {
assert.EqualValues(t, newSetting.SettingValue, settings[strings.ToLower(keyName)].SettingValue)
// updated setting
- updatedSetting := &system.Setting{SettingKey: keyName, SettingValue: "100", Version: newSetting.Version}
+ updatedSetting := &system.Setting{SettingKey: keyName, SettingValue: "100", Version: settings[strings.ToLower(keyName)].Version}
err = system.SetSetting(updatedSetting)
assert.NoError(t, err)
+ value, err := system.GetSetting(keyName)
+ assert.NoError(t, err)
+ assert.EqualValues(t, updatedSetting.SettingValue, value)
+
// get all settings
settings, err = system.GetAllSettings()
assert.NoError(t, err)