Replacing a1-python with a1-go implementation
[ric-plt/a1.git] / pkg / a1 / a1.go
diff --git a/pkg/a1/a1.go b/pkg/a1/a1.go
new file mode 100644 (file)
index 0000000..30ecc5d
--- /dev/null
@@ -0,0 +1,51 @@
+/*
+==================================================================================
+  Copyright (c) 2021 Samsung
+
+   Licensed under the Apache License, Version 2.0 (the "License");
+   you may not use this file except in compliance with the License.
+   You may obtain a copy of the License at
+
+       http://www.apache.org/licenses/LICENSE-2.0
+
+   Unless required by applicable law or agreed to in writing, software
+   distributed under the License is distributed on an "AS IS" BASIS,
+   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+   See the License for the specific language governing permissions and
+   limitations under the License.
+
+   This source code is part of the near-RT RIC (RAN Intelligent Controller)
+   platform project (RICP).
+==================================================================================
+*/
+package a1
+
+import (
+       "fmt"
+       "os"
+
+       mdclog "gerrit.o-ran-sc.org/r/com/golog"
+)
+
+var Logger *mdclog.MdcLogger
+
+func Init() {
+       var err error
+       Logger, err = mdclog.InitLogger("a1")
+       if err != nil {
+               fmt.Println("logger not initialised !!!")
+               return
+       }
+
+       // set config file to read logging config
+       configFile := os.Getenv("A1_CONFIG_FILE")
+       fmt.Println(configFile)
+
+       if configFile != "" {
+               Logger.ParseFileContent(configFile)
+               Logger.Info("logger is initialized with config file : %s", configFile)
+       } else {
+               Logger.LevelSet(mdclog.INFO)
+               Logger.Info("logger is initialized without config file.")
+       }
+}