Merge "Changing status to connected state after timeout."
[ric-plt/e2mgr.git] / E2Manager / services / rmrreceiver / rmr_receiver.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 //  This source code is part of the near-RT RIC (RAN Intelligent Controller)
18 //  platform project (RICP).
19
20
21 package rmrreceiver
22
23 import (
24         "e2mgr/logger"
25         "e2mgr/managers/notificationmanager"
26         "e2mgr/rmrCgo"
27 )
28
29 type RmrReceiver struct {
30         logger    *logger.Logger
31         nManager  *notificationmanager.NotificationManager
32         messenger rmrCgo.RmrMessenger
33 }
34
35 func NewRmrReceiver(logger *logger.Logger, messenger rmrCgo.RmrMessenger, nManager *notificationmanager.NotificationManager) *RmrReceiver {
36         return &RmrReceiver{
37                 logger:    logger,
38                 nManager:  nManager,
39                 messenger: messenger,
40         }
41 }
42
43 func (r *RmrReceiver) ListenAndHandle() {
44
45         for {
46                 mbuf, err := r.messenger.RecvMsg()
47
48                 if err != nil {
49                         r.logger.Errorf("#RmrReceiver.ListenAndHandle - error: %s", err)
50                         continue
51                 }
52
53                 r.logger.Debugf("#RmrReceiver.ListenAndHandle - Going to handle received message: %#v\n", mbuf)
54
55                 // TODO: go routine?
56                 _ = r.nManager.HandleMessage(mbuf)
57         }
58 }