980c867ad953dffe0a5e8abc0c8dd6e07c27c1b3
[ric-plt/e2mgr.git] / E2Manager / handlers / ran_lost_connection_handler.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 package handlers
19
20 import (
21         "e2mgr/logger"
22         "e2mgr/managers"
23         "e2mgr/models"
24         "e2mgr/sessions"
25 )
26
27 type RanLostConnectionHandler struct {
28         ranReconnectionManager managers.IRanReconnectionManager
29 }
30
31 func NewRanLostConnectionHandler(ranReconnectionManager managers.IRanReconnectionManager) RanLostConnectionHandler {
32         return RanLostConnectionHandler{
33                 ranReconnectionManager: ranReconnectionManager,
34         }
35 }
36 func (handler RanLostConnectionHandler) Handle(logger *logger.Logger, e2Sessions sessions.E2Sessions, request *models.NotificationRequest, messageChannel chan<- *models.NotificationResponse) {
37
38         ranName := request.TransactionId
39
40         // TODO: check with E2T dev why does request.RanName (MEID) does not contain the ran name (in case sim is down)
41         if len(request.RanName) > 0 {
42                 ranName = request.RanName
43         }
44
45         logger.Warnf("#RanLostConnectionHandler.Handle - RAN name: %s - Received lost connection notification", ranName)
46
47         err := handler.ranReconnectionManager.ReconnectRan(ranName)
48
49         if err != nil {
50                 logger.Errorf("#RanLostConnectionHandler.Handle - An error occurred while trying to reconnect RAN, %v", err)
51                 return
52         }
53 }