2022-02-11 11:02:47 +01:00
|
|
|
package initialise
|
|
|
|
|
2022-03-28 10:05:09 +02:00
|
|
|
import (
|
|
|
|
"github.com/caos/logging"
|
|
|
|
"github.com/caos/zitadel/internal/database"
|
|
|
|
"github.com/spf13/viper"
|
|
|
|
)
|
2022-02-11 11:02:47 +01:00
|
|
|
|
|
|
|
type Config struct {
|
2022-02-16 13:30:49 +01:00
|
|
|
Database database.Config
|
|
|
|
AdminUser database.User
|
2022-03-28 10:05:09 +02:00
|
|
|
Log *logging.Config
|
2022-02-16 13:30:49 +01:00
|
|
|
}
|
|
|
|
|
2022-03-28 10:05:09 +02:00
|
|
|
func MustNewConfig(v *viper.Viper) *Config {
|
|
|
|
config := new(Config)
|
|
|
|
err := v.Unmarshal(config)
|
|
|
|
logging.OnError(err).Fatal("unable to read config")
|
|
|
|
|
|
|
|
err = config.Log.SetLogger()
|
|
|
|
logging.OnError(err).Fatal("unable to set logger")
|
|
|
|
|
|
|
|
return config
|
|
|
|
}
|
|
|
|
|
|
|
|
func adminConfig(config *Config) database.Config {
|
2022-02-16 13:30:49 +01:00
|
|
|
adminConfig := config.Database
|
|
|
|
adminConfig.Username = config.AdminUser.Username
|
|
|
|
adminConfig.Password = config.AdminUser.Password
|
|
|
|
adminConfig.SSL.Cert = config.AdminUser.SSL.Cert
|
|
|
|
adminConfig.SSL.Key = config.AdminUser.SSL.Key
|
|
|
|
if config.AdminUser.SSL.RootCert != "" {
|
|
|
|
adminConfig.SSL.RootCert = config.AdminUser.SSL.RootCert
|
|
|
|
}
|
|
|
|
if config.AdminUser.SSL.Mode != "" {
|
|
|
|
adminConfig.SSL.Mode = config.AdminUser.SSL.Mode
|
|
|
|
}
|
|
|
|
//use default database because the zitadel database might not exist
|
|
|
|
adminConfig.Database = ""
|
|
|
|
|
|
|
|
return adminConfig
|
2022-02-11 11:02:47 +01:00
|
|
|
}
|