12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 |
- package config
- import (
- "fmt"
- "io/ioutil"
- "os"
- "gopkg.in/yaml.v3"
- "wkla.no-ip.biz/gogs/Willie/MsgService/MessageService/logging"
- )
- var config = Config{
- Port: 9080,
- Sslport: 9443,
- ServiceURL: "http://127.0.0.1",
- SystemID: "autorest-srv",
- AllowAnonymousBackend: false,
- HealthCheck: HealthCheck{
- Period: 30,
- },
- }
- // File the config file
- var File = "config/service.yaml"
- var log logging.ServiceLogger
- // Get returns loaded config
- func Get() Config {
- return config
- }
- // Load loads the config
- func Load() error {
- _, err := os.Stat(File)
- if err != nil {
- return err
- }
- data, err := ioutil.ReadFile(File)
- if err != nil {
- return fmt.Errorf("can't load config file: %s", err.Error())
- }
- err = yaml.Unmarshal(data, &config)
- if err != nil {
- return fmt.Errorf("can't unmarshal config file: %s", err.Error())
- }
- readSecret()
- value, _ := yaml.Marshal(config)
- log.Infof("using configfile %s. \nconfiguration:\n%s\n", File, string(value))
- return nil
- }
- func readSecret() error {
- secretFile := config.SecretFile
- if secretFile != "" {
- data, err := ioutil.ReadFile(secretFile)
- if err != nil {
- return fmt.Errorf("can't load secret file: %s", err.Error())
- }
- var secretConfig Secret = Secret{}
- err = yaml.Unmarshal(data, &secretConfig)
- if err != nil {
- return fmt.Errorf("can't unmarshal secret file: %s", err.Error())
- }
- mergeSecret(secretConfig)
- }
- return nil
- }
- func mergeSecret(secret Secret) {
- config.MongoDB.Username = secret.MongoDB.Username
- config.MongoDB.Password = secret.MongoDB.Password
- }
|