diff options
author | zeripath <art27@cantab.net> | 2020-09-25 09:58:09 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-09-25 09:58:09 +0100 |
commit | f1ab1c532b86eb25ef3f683f690a7f29572144f6 (patch) | |
tree | a81dbb07f5360e30e4c225b0802e70d4bc7b4142 | |
parent | 3c360801b3547cba80766403c0ee2835cb81272d (diff) | |
download | gitea-f1ab1c532b86eb25ef3f683f690a7f29572144f6.tar.gz gitea-f1ab1c532b86eb25ef3f683f690a7f29572144f6.zip |
Allow extended config on cron settings (#12939)
* Allow extended config on cron settings
Fix #12934
Signed-off-by: Andrew Thornton <art27@cantab.net>
-rw-r--r-- | modules/setting/cron.go | 22 | ||||
-rw-r--r-- | modules/setting/cron_test.go | 47 |
2 files changed, 67 insertions, 2 deletions
diff --git a/modules/setting/cron.go b/modules/setting/cron.go index c8228ddaa8..9475887ecc 100644 --- a/modules/setting/cron.go +++ b/modules/setting/cron.go @@ -4,8 +4,26 @@ package setting +import "reflect" + // GetCronSettings maps the cron subsection to the provided config func GetCronSettings(name string, config interface{}) (interface{}, error) { - err := Cfg.Section("cron." + name).MapTo(config) - return config, err + if err := Cfg.Section("cron." + name).MapTo(config); err != nil { + return config, err + } + + typ := reflect.TypeOf(config).Elem() + val := reflect.ValueOf(config).Elem() + + for i := 0; i < typ.NumField(); i++ { + field := val.Field(i) + tpField := typ.Field(i) + if tpField.Type.Kind() == reflect.Struct && tpField.Anonymous { + if err := Cfg.Section("cron." + name).MapTo(field.Addr().Interface()); err != nil { + return config, err + } + } + } + + return config, nil } diff --git a/modules/setting/cron_test.go b/modules/setting/cron_test.go new file mode 100644 index 0000000000..8670a92bac --- /dev/null +++ b/modules/setting/cron_test.go @@ -0,0 +1,47 @@ +// Copyright 2020 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 ( + "testing" + + "github.com/stretchr/testify/assert" + ini "gopkg.in/ini.v1" +) + +func Test_GetCronSettings(t *testing.T) { + + type BaseStruct struct { + Base bool + Second string + } + + type Extended struct { + BaseStruct + Extend bool + } + + iniStr := ` +[cron.test] +Base = true +Second = white rabbit +Extend = true +` + Cfg, _ = ini.Load([]byte(iniStr)) + + extended := &Extended{ + BaseStruct: BaseStruct{ + Second: "queen of hearts", + }, + } + + _, err := GetCronSettings("test", extended) + + assert.NoError(t, err) + assert.True(t, extended.Base) + assert.EqualValues(t, extended.Second, "white rabbit") + assert.True(t, extended.Extend) + +} |