X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=E2Manager%2Fmanagers%2Fe2t_association_manager.go;fp=E2Manager%2Fmanagers%2Fe2t_association_manager.go;h=3afba253df0e6933b230a0adc28012cec60c70a5;hb=b3805a9d29e2c7f6f14e3fedfa1ba504f734eea9;hp=855ac05094788e62d289c18a8273748151146691;hpb=f1035e286c9cdb58fd786daf4d6c5cc9bea45a37;p=ric-plt%2Fe2mgr.git diff --git a/E2Manager/managers/e2t_association_manager.go b/E2Manager/managers/e2t_association_manager.go index 855ac05..3afba25 100644 --- a/E2Manager/managers/e2t_association_manager.go +++ b/E2Manager/managers/e2t_association_manager.go @@ -21,6 +21,7 @@ package managers import ( "e2mgr/clients" + "e2mgr/e2managererrors" "e2mgr/logger" "e2mgr/services" "gerrit.o-ran-sc.org/r/ric-plt/nodeb-rnib.git/entities" @@ -46,28 +47,43 @@ func (m *E2TAssociationManager) AssociateRan(e2tAddress string, nodebInfo *entit ranName := nodebInfo.RanName m.logger.Infof("#E2TAssociationManager.AssociateRan - Associating RAN %s to E2T Instance address: %s", ranName, e2tAddress) - nodebInfo.AssociatedE2TInstanceAddress = e2tAddress - nodebInfo.ConnectionAttempts = 0 - - rnibErr := m.rnibDataService.UpdateNodebInfo(nodebInfo) - if rnibErr != nil { - m.logger.Errorf("#E2TAssociationManager.AssociateRan - RAN name: %s - Failed to update RAN.AssociatedE2TInstanceAddress in rNib. Error: %s", ranName, rnibErr) - return rnibErr - } - - err := m.e2tInstanceManager.AddRansToInstance(e2tAddress, []string{ranName}) + err := m.associateRanAndUpdateNodeb(e2tAddress, nodebInfo) if err != nil { - m.logger.Errorf("#E2TAssociationManager.AssociateRan - RAN name: %s - Failed to add RAN to E2T instance %s. Error: %s", ranName, e2tAddress, err) + m.logger.Errorf("#E2TAssociationManager.AssociateRan - RoutingManager failure: Failed to associate RAN %s to E2T %s. Error: %s", nodebInfo, e2tAddress, err) return err } - err = m.rmClient.AssociateRanToE2TInstance(e2tAddress, ranName) + err = m.e2tInstanceManager.AddRansToInstance(e2tAddress, []string{ranName}) if err != nil { - m.logger.Errorf("#E2TAssociationManager.AssociateRan - RoutingManager failure: Failed to associate RAN %s to E2T %s. Error: %s", ranName, e2tAddress, err) + m.logger.Errorf("#E2TAssociationManager.AssociateRan - RAN name: %s - Failed to add RAN to E2T instance %s. Error: %s", ranName, e2tAddress, err) + return e2managererrors.NewRnibDbError() } m.logger.Infof("#E2TAssociationManager.AssociateRan - successfully associated RAN %s with E2T %s", ranName, e2tAddress) return nil } +func (m *E2TAssociationManager) associateRanAndUpdateNodeb(e2tAddress string, nodebInfo *entities.NodebInfo) error { + + rmErr := m.rmClient.AssociateRanToE2TInstance(e2tAddress, nodebInfo.RanName) + if rmErr != nil { + nodebInfo.ConnectionStatus = entities.ConnectionStatus_DISCONNECTED + } else { + nodebInfo.ConnectionStatus = entities.ConnectionStatus_CONNECTED + nodebInfo.AssociatedE2TInstanceAddress = e2tAddress + nodebInfo.ConnectionAttempts = 0 + } + rNibErr := m.rnibDataService.UpdateNodebInfo(nodebInfo) + if rNibErr != nil { + m.logger.Errorf("#E2TAssociationManager.associateRanAndUpdateNodeb - RAN name: %s - Failed to update nodeb entity in rNib. Error: %s", nodebInfo.RanName, rNibErr) + } + var err error + if rmErr != nil { + err = e2managererrors.NewRoutingManagerError() + } else if rNibErr != nil{ + err = e2managererrors.NewRnibDbError() + } + return err +} + func (m *E2TAssociationManager) DissociateRan(e2tAddress string, ranName string) error { m.logger.Infof("#E2TAssociationManager.DissociateRan - Dissociating RAN %s from E2T Instance address: %s", ranName, e2tAddress)