d85d980f8df6051a293110d1635518a466949b30
[ric-plt/e2mgr.git] / tools / xappmock / main / xappmock.go
1 //
2 // Copyright 2019 AT&T Intellectual Property
3 // Copyright 2019 Nokia
4 //
5 // Licensed under the Apache License, Version 2.0 (the "License");
6 // you may not use this file except in compliance with the License.
7 // You may obtain a copy of the License at
8 //
9 //      http://www.apache.org/licenses/LICENSE-2.0
10 //
11 // Unless required by applicable law or agreed to in writing, software
12 // distributed under the License is distributed on an "AS IS" BASIS,
13 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 // See the License for the specific language governing permissions and
15 // limitations under the License.
16 //
17
18 //  This source code is part of the near-RT RIC (RAN Intelligent Controller)
19 //  platform project (RICP).
20
21 package main
22
23 import (
24         "context"
25         "flag"
26         "fmt"
27         "os"
28         "os/signal"
29         "strconv"
30         "time"
31         "xappmock/dispatcher"
32         "xappmock/frontend"
33         "xappmock/logger"
34         "xappmock/rmr"
35         "xappmock/sender"
36 )
37
38 const (
39         ENV_RMR_PORT     = "RMR_PORT"
40         RMR_PORT_DEFAULT = 5001
41 )
42
43 var rmrService *rmr.Service
44
45 func main() {
46
47         //logLevel, _ := logger.LogLevelTokenToLevel("info")
48         logLevel := int8(1)
49         logger, err := logger.InitLogger(logLevel)
50         if err != nil {
51                 fmt.Printf("#app.main - failed to initialize logger, error: %s", err)
52                 os.Exit(1)
53         }
54
55         var rmrContext *rmr.Context
56         var rmrConfig = rmr.Config{Port: RMR_PORT_DEFAULT, MaxMsgSize: rmr.RMR_MAX_MSG_SIZE, MaxRetries: 10, Flags: 0}
57
58         if port, err := strconv.ParseUint(os.Getenv(ENV_RMR_PORT), 10, 16); err == nil {
59                 rmrConfig.Port = int(port)
60         } else {
61                 logger.Infof("#main - %s: %s, using default (%d).", ENV_RMR_PORT, err, RMR_PORT_DEFAULT)
62         }
63
64         rmrService = rmr.NewService(rmrConfig, rmrContext)
65         jsonSender := sender.NewJsonSender(logger)
66         dispatcherDesc := dispatcher.New(logger, rmrService, jsonSender)
67
68         /* Load configuration file*/
69         err = frontend.ProcessConfigurationFile("resources", "conf", ".json",
70                 func(data []byte) error {
71                         return frontend.JsonCommandsDecoder(data, dispatcherDesc.JsonCommandsDecoderCB)
72                 })
73
74         if err != nil {
75                 logger.Errorf("#main - processing error: %s", err)
76                 os.Exit(1)
77         }
78
79         logger.Infof("#main - xApp Mock is up and running...")
80
81         flag.Parse()
82         cmd := flag.Arg(0) /*first remaining argument after flags have been processed*/
83
84         command, err := frontend.DecodeJsonCommand([]byte(cmd))
85
86         if err != nil {
87                 logger.Errorf("#main - command decoding error: %s", err)
88                 rmrService.CloseContext()
89                 logger.Infof("#main - xApp Mock is down")
90                 return
91         }
92
93         c := make(chan os.Signal, 1)
94         signal.Notify(c, os.Interrupt)
95         ctx, cancel := context.WithCancel(context.Background())
96
97         go func() {
98                 oscall := <-c
99                 logger.Infof("system call:%+v", oscall)
100                 cancel()
101                 rmrService.CloseContext()
102         }()
103
104         dispatcherDesc.ProcessJsonCommand(ctx, command)
105         pr := dispatcherDesc.GetProcessResult()
106
107         if pr.Err != nil {
108                 logger.Errorf("#main - command processing Error: %s", pr.Err)
109         }
110
111         if pr.StartTime != nil {
112                 processElapsedTimeInMs := float64(time.Since(*pr.StartTime)) / float64(time.Millisecond)
113                 logger.Infof("#main - processing (sending/receiving) messages took %.2f ms", processElapsedTimeInMs)
114
115         }
116         logger.Infof("#main - process stats: %s", pr.Stats)
117
118         rmrService.CloseContext() // TODO: called twice
119         logger.Infof("#main - xApp Mock is down")
120 }