/
loader.go
48 lines (41 loc) · 1.34 KB
/
loader.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
package configsource
import (
"errors"
"fmt"
"github.com/authgear/authgear-server/pkg/lib/config"
"github.com/authgear/authgear-server/pkg/util/resource"
)
func LoadConfig(res *resource.Manager) (*config.Config, error) {
result, err := res.Read(AppConfig, resource.EffectiveResource{})
if errors.Is(err, resource.ErrResourceNotFound) {
return nil, fmt.Errorf("missing '%s': %w", AuthgearYAML, err)
} else if err != nil {
return nil, err
}
appConfig := result.(*config.AppConfig)
result, err = res.Read(SecretConfig, resource.EffectiveResource{})
if errors.Is(err, resource.ErrResourceNotFound) {
return nil, fmt.Errorf("missing '%s': %w", AuthgearSecretYAML, err)
} else if err != nil {
return nil, err
}
secretConfig := result.(*config.SecretConfig)
var featureConfig *config.FeatureConfig
result, err = res.Read(FeatureConfig, resource.EffectiveResource{})
if errors.Is(err, resource.ErrResourceNotFound) {
featureConfig = config.NewEffectiveDefaultFeatureConfig()
} else if err != nil {
return nil, err
} else {
featureConfig = result.(*config.FeatureConfig)
}
cfg := &config.Config{
AppConfig: appConfig,
SecretConfig: secretConfig,
FeatureConfig: featureConfig,
}
if err = cfg.SecretConfig.Validate(cfg.AppConfig); err != nil {
return nil, fmt.Errorf("invalid secret config: %w", err)
}
return cfg, nil
}