Implement custom onboard functionality
[ric-plt/ricdms.git] / pkg / ricdms / ricdms.go
1 //==================================================================================
2 //  Copyright (c) 2022 Samsung
3 //
4 //   Licensed under the Apache License, Version 2.0 (the "License");
5 //   you may not use this file except in compliance with the License.
6 //   You may obtain a copy of the License at
7 //
8 //       http://www.apache.org/licenses/LICENSE-2.0
9 //
10 //   Unless required by applicable law or agreed to in writing, software
11 //   distributed under the License is distributed on an "AS IS" BASIS,
12 //   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 //   See the License for the specific language governing permissions and
14 //   limitations under the License.
15 //
16 //   This source code is part of the near-RT RIC (RAN Intelligent Controller)
17 //   platform project (RICP).
18 //==================================================================================
19 //
20
21 package ricdms
22
23 import (
24         "fmt"
25         "os"
26
27         mdclog "gerrit.o-ran-sc.org/r/com/golog"
28         "gerrit.o-ran-sc.org/r/ric-plt/ricdms/pkg/config"
29 )
30
31 type ricdms struct {
32 }
33
34 var Logger *mdclog.MdcLogger
35 var Config *config.Conf
36
37 func Init() {
38         var err error
39         Logger, err = mdclog.InitLogger("ricdms")
40         if err != nil {
41                 fmt.Println("Logger not initialized !!")
42                 return
43         }
44
45         configFile := os.Getenv("RIC_DMS_CONFIG_FILE")
46
47         if configFile != "" {
48                 Logger.ParseFileContent(configFile)
49                 Config, err = config.ReadConfiguration(configFile)
50                 if err != nil {
51                         Logger.Error("Error in parsing config file: %v", err)
52                 }
53                 Logger.Info("Logger is initialized with config file : %s", configFile)
54         } else {
55                 Logger.LevelSet(mdclog.INFO)
56                 Logger.Info("Logger is initialized without config file(%s).", configFile)
57         }
58 }