50e12ee1dbcf28e9a1d14fd179fd86d48ca42d54
[ric-plt/e2mgr.git] / E2Manager / handlers / ranLostConnectionHandler.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         logger.Warnf("#RanLostConnectionHandler.Handle - RAN name: %s - Received lost connection notification", request.RanName)
39
40         err := handler.ranReconnectionManager.ReconnectRan(request.RanName)
41
42         if err != nil {
43                 logger.Errorf("#RanLostConnectionHandler.Handle - An error occurred while trying to reconnect RAN, %v", err)
44                 return
45         }
46 }