2 // Copyright 2019 AT&T Intellectual Property
3 // Copyright 2019 Nokia
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
9 // http://www.apache.org/licenses/LICENSE-2.0
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.
17 // This source code is part of the near-RT RIC (RAN Intelligent Controller)
18 // platform project (RICP).
23 "e2mgr/e2managererrors"
26 "gerrit.o-ran-sc.org/r/ric-plt/nodeb-rnib.git/entities"
31 type ranListManagerInstance struct {
33 rnibDataService services.RNibDataService
35 nbIdentityMap map[string]*entities.NbIdentity
38 type RanListManager interface {
39 InitNbIdentityMap() error
40 AddNbIdentity(nodeType entities.Node_Type, nbIdentity *entities.NbIdentity) error
41 UpdateNbIdentityConnectionStatus(nodeType entities.Node_Type, ranName string, connectionStatus entities.ConnectionStatus) error
42 RemoveNbIdentity(nodeType entities.Node_Type, ranName string) error
43 GetNbIdentityList() []*entities.NbIdentity
44 UpdateHealthcheckTimeStampReceived(oldRRanName string) (*entities.NbIdentity, *entities.NbIdentity)
45 UpdateHealthcheckTimeStampSent(oldRRanName string) (*entities.NbIdentity, *entities.NbIdentity)
46 UpdateNbIdentities(nodeType entities.Node_Type, oldNbIdentities []*entities.NbIdentity, newNbIdentities []*entities.NbIdentity) error
49 func NewRanListManager(logger *logger.Logger, rnibDataService services.RNibDataService) RanListManager {
50 return &ranListManagerInstance{
52 rnibDataService: rnibDataService,
53 nbIdentityMap: make(map[string]*entities.NbIdentity),
57 func (m *ranListManagerInstance) InitNbIdentityMap() error {
58 nbIds, err := m.rnibDataService.GetListNodebIds()
61 m.logger.Errorf("#ranListManagerInstance.InitNbIdentityMap - Failed fetching RAN list from DB. error: %s", err)
65 for _, v := range nbIds {
66 m.nbIdentityMap[v.InventoryName] = v
69 m.logger.Infof("#ranListManagerInstance.InitNbIdentityMap - Successfully initiated nodeb identity map")
70 m.logger.Debugf("#ranListManagerInstance.InitNbIdentityMap - nodeb Identity map: %s", m.nbIdentityMap)
74 func (m *ranListManagerInstance) AddNbIdentity(nodeType entities.Node_Type, nbIdentity *entities.NbIdentity) error {
78 m.nbIdentityMap[nbIdentity.InventoryName] = nbIdentity
80 err := m.rnibDataService.AddNbIdentity(nodeType, nbIdentity)
83 m.logger.Errorf("#ranListManagerInstance.AddNbIdentity - RAN name: %s - Failed adding nodeb identity to DB. error: %s", nbIdentity.InventoryName, err)
87 m.logger.Infof("#ranListManagerInstance.AddNbIdentity - RAN name: %s - Successfully added nodeb identity", nbIdentity.InventoryName)
88 m.logger.Debugf("#ranListManagerInstance.AddNbIdentity - nodeb Identity map: %s", m.nbIdentityMap)
92 func (m *ranListManagerInstance) UpdateNbIdentityConnectionStatus(nodeType entities.Node_Type, ranName string, connectionStatus entities.ConnectionStatus) error {
96 m.logger.Infof("#ranListManagerInstance.UpdateNbIdentityConnectionStatus - RAN name: %s - updating nodeb identity connection status", ranName)
98 oldNbIdentity, ok := m.nbIdentityMap[ranName]
100 m.logger.Errorf("#ranListManagerInstance.UpdateNbIdentityConnectionStatus - RAN name: %s - nodeb identity not found in nbIdentityMap", ranName)
101 return e2managererrors.NewInternalError()
104 newNbIdentity := &entities.NbIdentity{
105 GlobalNbId: oldNbIdentity.GlobalNbId,
106 InventoryName: ranName,
107 ConnectionStatus: connectionStatus,
108 HealthCheckTimestampSent: oldNbIdentity.HealthCheckTimestampSent,
109 HealthCheckTimestampReceived: oldNbIdentity.HealthCheckTimestampReceived,
111 m.nbIdentityMap[ranName] = newNbIdentity
113 err := m.rnibDataService.UpdateNbIdentity(nodeType, oldNbIdentity, newNbIdentity)
115 m.logger.Errorf("#ranListManagerInstance.UpdateNbIdentityConnectionStatus - RAN name: %s - Failed updating nodeb identity in DB. error: %s", ranName, err)
118 m.logger.Infof("#ranListManagerInstance.UpdateNbIdentityConnectionStatus - RAN name: %s - Successfully updated nodeb identity", ranName)
122 func (m *ranListManagerInstance) RemoveNbIdentity(nodeType entities.Node_Type, ranName string) error {
126 m.logger.Infof("#ranListManagerInstance.RemoveNbIdentity - RAN name: %s - deleting nodeb identity from memory and db...", ranName)
128 nbIdentity, ok := m.nbIdentityMap[ranName]
130 m.logger.Infof("#ranListManagerInstance.RemoveNbIdentity - RAN name: %s - nodeb identity not found", ranName)
134 delete(m.nbIdentityMap, ranName)
136 err := m.rnibDataService.RemoveNbIdentity(nodeType, nbIdentity)
138 m.logger.Errorf("#ranListManagerInstance.RemoveNbIdentity - RAN name: %s - Failed removing nodeb identity from DB. error: %s", ranName, err)
142 m.logger.Infof("#ranListManagerInstance.RemoveNbIdentity - RAN name: %s - Successfully deleted nodeb identity", ranName)
146 func (m *ranListManagerInstance) GetNbIdentityList() []*entities.NbIdentity {
147 nbIds := make([]*entities.NbIdentity, 0, len(m.nbIdentityMap))
148 for _, v := range m.nbIdentityMap {
149 nbIds = append(nbIds, v)
152 m.logger.Infof("#ranListManagerInstance.GetNbIdentityList - %d identity returned", len(nbIds))
157 func (m *ranListManagerInstance) UpdateHealthcheckTimeStampSent(oldRRanName string) (*entities.NbIdentity, *entities.NbIdentity){
158 currentTimeStamp := time.Now().UnixNano()
159 oldNbIdentity := m.nbIdentityMap[oldRRanName]
161 newNbIdentity := &entities.NbIdentity{
162 GlobalNbId: oldNbIdentity.GlobalNbId,
163 InventoryName: oldNbIdentity.InventoryName,
164 ConnectionStatus: oldNbIdentity.ConnectionStatus,
165 HealthCheckTimestampSent: currentTimeStamp,
166 HealthCheckTimestampReceived: oldNbIdentity.HealthCheckTimestampReceived,
169 m.nbIdentityMap[oldNbIdentity.InventoryName] = newNbIdentity
170 return oldNbIdentity, newNbIdentity
173 func (m *ranListManagerInstance) UpdateHealthcheckTimeStampReceived(oldRRanName string) (*entities.NbIdentity, *entities.NbIdentity){
174 currentTimeStamp := time.Now().UnixNano()
175 oldNbIdentity := m.nbIdentityMap[oldRRanName]
177 newNbIdentity := &entities.NbIdentity{
178 GlobalNbId: oldNbIdentity.GlobalNbId,
179 InventoryName: oldNbIdentity.InventoryName,
180 ConnectionStatus: oldNbIdentity.ConnectionStatus,
181 HealthCheckTimestampSent: oldNbIdentity.HealthCheckTimestampSent,
182 HealthCheckTimestampReceived: currentTimeStamp,
185 m.nbIdentityMap[oldNbIdentity.InventoryName] = newNbIdentity
186 return oldNbIdentity, newNbIdentity
189 func (m *ranListManagerInstance) UpdateNbIdentities(nodeType entities.Node_Type, oldNbIdentities []*entities.NbIdentity, newNbIdentities []*entities.NbIdentity) error {
193 err:= m.rnibDataService.UpdateNbIdentities(nodeType, oldNbIdentities, newNbIdentities)