X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=pkg%2Fxapp%2Fconfig.go;h=56986d31caf0a2282a12a630ef7517adfb18c605;hb=bb554448a2eb866606db0fea7a1d689005569ff4;hp=49c5e0a6d3f63acc6fa4c5a53439426961f7118e;hpb=065fa1d2c42d0bdf6863e634a75f470fb532f612;p=ric-plt%2Fxapp-frame.git diff --git a/pkg/xapp/config.go b/pkg/xapp/config.go old mode 100644 new mode 100755 index 49c5e0a..56986d3 --- a/pkg/xapp/config.go +++ b/pkg/xapp/config.go @@ -21,6 +21,7 @@ package xapp import ( "flag" + "fmt" "github.com/fsnotify/fsnotify" "github.com/spf13/viper" "os" @@ -41,6 +42,8 @@ type Configurator struct { type ConfigChangeCB func(filename string) +type SDLNotificationCB func(string, ...string) + var ConfigChangeListeners []ConfigChangeCB func parseCmd() string { @@ -60,9 +63,9 @@ func LoadConfig() (l *Log) { } l.Info("Using config file: %s", viper.ConfigFileUsed()) - updatemtypes := func() { + updateMTypes := func() { var mtypes []mtype - viper.UnmarshalKey("rmr.mtypes", &mtypes) + viper.UnmarshalKey("messaging.mtypes", &mtypes) if len(mtypes) > 0 { l.Info("Config mtypes before RICMessageTypes:%d RicMessageTypeToName:%d", len(RICMessageTypes), len(RicMessageTypeToName)) @@ -89,14 +92,19 @@ func LoadConfig() (l *Log) { } } - updatemtypes() + updateMTypes() viper.WatchConfig() viper.OnConfigChange(func(e fsnotify.Event) { l.Info("config file %s changed ", e.Name) - updatemtypes() - Logger.SetLevel(viper.GetInt("logger.level")) + updateMTypes() + if viper.IsSet("controls.logger.level") { + Logger.SetLevel(viper.GetInt("controls.logger.level")) + } else { + Logger.SetLevel(viper.GetInt("logger.level")) + } + if len(ConfigChangeListeners) > 0 { for _, f := range ConfigChangeListeners { go f(e.Name) @@ -114,6 +122,74 @@ func AddConfigChangeListener(f ConfigChangeCB) { ConfigChangeListeners = append(ConfigChangeListeners, f) } +func PublishConfigChange(appName, eventJson string) error { + channel := fmt.Sprintf("CM_UPDATE:%s", appName) + if err := SdlStorage.StoreAndPublish(getCmSdlNs(), channel, eventJson, appName, eventJson); err != nil { + Logger.Error("Sdl.Store failed: %v", err) + return err + } + return nil +} + +func ReadConfig(appName string) (map[string]interface{}, error) { + return SdlStorage.Read(getCmSdlNs(), appName) +} + +func GetPortData(pname string) (d PortData) { + var getPolicies = func(policies []interface{}) (plist []int) { + for _, p := range policies { + plist = append(plist, int(p.(float64))) + } + return plist + } + + if viper.IsSet("messaging") == false { + if pname == "http" { + d.Port = 8080 + } + if pname == "rmrdata" { + d.Port = 4560 + } + return + } + + for _, v := range viper.GetStringMap("messaging")["ports"].([]interface{}) { + if n, ok := v.(map[string]interface{})["name"].(string); ok && n == pname { + d.Name = n + if p, _ := v.(map[string]interface{})["port"].(float64); ok { + d.Port = int(p) + } + if m, _ := v.(map[string]interface{})["maxSize"].(float64); ok { + d.MaxSize = int(m) + } + if m, _ := v.(map[string]interface{})["threadType"].(float64); ok { + d.ThreadType = int(m) + } + if m, _ := v.(map[string]interface{})["lowLatency"].(bool); ok { + d.LowLatency = bool(m) + } + if m, _ := v.(map[string]interface{})["fastAck"].(bool); ok { + d.FastAck = bool(m) + } + if m, _ := v.(map[string]interface{})["maxRetryOnFailure"].(float64); ok { + d.MaxRetryOnFailure = int(m) + } + if policies, ok := v.(map[string]interface{})["policies"]; ok { + d.Policies = getPolicies(policies.([]interface{})) + } + } + } + return +} + +func getCmSdlNs() string { + return fmt.Sprintf("cm/%s", viper.GetString("name")) +} + +func (*Configurator) SetSDLNotificationCB(appName string, sdlNotificationCb SDLNotificationCB) error { + return SdlStorage.Subscribe(getCmSdlNs(), sdlNotificationCb, fmt.Sprintf("CM_UPDATE:%s", appName)) +} + func (*Configurator) GetString(key string) string { return viper.GetString(key) } @@ -141,3 +217,7 @@ func (*Configurator) GetStringSlice(key string) []string { func (*Configurator) GetStringMap(key string) map[string]interface{} { return viper.GetStringMap(key) } + +func (*Configurator) IsSet(key string) bool { + return viper.IsSet(key) +}