X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=E2Manager%2Fmanagers%2Fe2t_association_manager.go;h=9ebdd604f5b275fe1c1d2973a00ca4a32a116088;hb=fb1e406498460f92ce4664ea060e43878a6c868e;hp=1b105b0f99a3f0bdc155a83fe2c6486db873a141;hpb=380b7a2a46087a054ebfac57f3dbf7949d318cc6;p=ric-plt%2Fe2mgr.git diff --git a/E2Manager/managers/e2t_association_manager.go b/E2Manager/managers/e2t_association_manager.go index 1b105b0..9ebdd60 100644 --- a/E2Manager/managers/e2t_association_manager.go +++ b/E2Manager/managers/e2t_association_manager.go @@ -21,53 +21,72 @@ package managers import ( "e2mgr/clients" + "e2mgr/e2managererrors" "e2mgr/logger" "e2mgr/services" "gerrit.o-ran-sc.org/r/ric-plt/nodeb-rnib.git/entities" ) type E2TAssociationManager struct { - logger *logger.Logger - rnibDataService services.RNibDataService - e2tInstanceManager IE2TInstancesManager - rmClient clients.IRoutingManagerClient + logger *logger.Logger + rnibDataService services.RNibDataService + e2tInstanceManager IE2TInstancesManager + rmClient clients.IRoutingManagerClient + ranConnectStatusChangeManager IRanConnectStatusChangeManager } -func NewE2TAssociationManager(logger *logger.Logger, rnibDataService services.RNibDataService, e2tInstanceManager IE2TInstancesManager, rmClient clients.IRoutingManagerClient) *E2TAssociationManager { +func NewE2TAssociationManager(logger *logger.Logger, rnibDataService services.RNibDataService, e2tInstanceManager IE2TInstancesManager, rmClient clients.IRoutingManagerClient, ranConnectStatusChangeManager IRanConnectStatusChangeManager) *E2TAssociationManager { return &E2TAssociationManager{ - logger: logger, - rnibDataService: rnibDataService, - e2tInstanceManager: e2tInstanceManager, - rmClient: rmClient, + logger: logger, + rnibDataService: rnibDataService, + e2tInstanceManager: e2tInstanceManager, + rmClient: rmClient, + ranConnectStatusChangeManager: ranConnectStatusChangeManager, } } -func (m *E2TAssociationManager) AssociateRan(e2tAddress string, nodebInfo *entities.NodebInfo) error { +func (m *E2TAssociationManager) AssociateRan(e2tAddress string, nodebInfo *entities.NodebInfo) (bool, error) { ranName := nodebInfo.RanName m.logger.Infof("#E2TAssociationManager.AssociateRan - Associating RAN %s to E2T Instance address: %s", ranName, e2tAddress) - err := m.rmClient.AssociateRanToE2TInstance(e2tAddress, ranName) + ranStatusChangePublished, err := m.associateRanAndUpdateNodeb(e2tAddress, nodebInfo) if err != nil { - m.logger.Errorf("#E2TAssociationManager.AssociateRan - RoutingManager failure: Failed to associate RAN %s to E2T %s. Error: %s", ranName, e2tAddress, err) - return err + m.logger.Errorf("#E2TAssociationManager.AssociateRan - RoutingManager failure: Failed to associate RAN %s to E2T %s. Error: %s", nodebInfo, e2tAddress, err) + return ranStatusChangePublished, err + } + err = m.e2tInstanceManager.AddRansToInstance(e2tAddress, []string{ranName}) + if err != nil { + m.logger.Errorf("#E2TAssociationManager.AssociateRan - RAN name: %s - Failed to add RAN to E2T instance %s. Error: %s", ranName, e2tAddress, err) + return ranStatusChangePublished, e2managererrors.NewRnibDbError() } + m.logger.Infof("#E2TAssociationManager.AssociateRan - successfully associated RAN %s with E2T %s", ranName, e2tAddress) + return ranStatusChangePublished, nil +} - nodebInfo.AssociatedE2TInstanceAddress = e2tAddress - nodebInfo.ConnectionAttempts = 0 +func (m *E2TAssociationManager) associateRanAndUpdateNodeb(e2tAddress string, nodebInfo *entities.NodebInfo) (bool, error) { + + rmErr := m.rmClient.AssociateRanToE2TInstance(e2tAddress, nodebInfo.RanName) + + if rmErr != nil { + ranStatusChangePublished, _ := m.ranConnectStatusChangeManager.ChangeStatus(nodebInfo, entities.ConnectionStatus_DISCONNECTED) + return ranStatusChangePublished, e2managererrors.NewRoutingManagerError() + } + + ranStatusChangePublished, rnibErr := m.ranConnectStatusChangeManager.ChangeStatus(nodebInfo, entities.ConnectionStatus_CONNECTED) - 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 + return ranStatusChangePublished, e2managererrors.NewRnibDbError() } - err = m.e2tInstanceManager.AddRansToInstance(e2tAddress, []string{ranName}) - if err != nil { - m.logger.Errorf("#E2TAssociationManager.AssociateRan - RAN name: %s - Failed to add RAN to E2T instance %s. Error: %s", ranName, e2tAddress, err) - return err + nodebInfo.AssociatedE2TInstanceAddress = e2tAddress + rnibErr = m.rnibDataService.UpdateNodebInfo(nodebInfo) + + if rnibErr != nil { + m.logger.Errorf("#E2TAssociationManager.associateRanAndUpdateNodeb - RAN name: %s - Failed updating nodeb. Error: %s", nodebInfo.RanName, rnibErr) + return ranStatusChangePublished, e2managererrors.NewRnibDbError() } - m.logger.Infof("#E2TAssociationManager.AssociateRan - successfully associated RAN %s with E2T %s", ranName, e2tAddress) - return nil + + return ranStatusChangePublished, nil } func (m *E2TAssociationManager) DissociateRan(e2tAddress string, ranName string) error { @@ -93,6 +112,7 @@ func (m *E2TAssociationManager) DissociateRan(e2tAddress string, ranName string) } err = m.rmClient.DissociateRanE2TInstance(e2tAddress, ranName) + if err != nil { m.logger.Errorf("#E2TAssociationManager.DissociateRan - RoutingManager failure: Failed to dissociate RAN %s from E2T %s. Error: %s", ranName, e2tAddress, err) } else { @@ -101,14 +121,13 @@ func (m *E2TAssociationManager) DissociateRan(e2tAddress string, ranName string) return nil } -func (m *E2TAssociationManager) RemoveE2tInstance(e2tInstance *entities.E2TInstance, ransToBeDissociated []string, ranAssociationList map[string][]string) error { - m.logger.Infof("#E2TAssociationManager.RemoveE2tInstance - Removing E2T %s and re-associating its associated RANs.", e2tInstance.Address) +func (m *E2TAssociationManager) RemoveE2tInstance(e2tInstance *entities.E2TInstance) error { + m.logger.Infof("#E2TAssociationManager.RemoveE2tInstance - Removing E2T %s and dessociating its associated RANs.", e2tInstance.Address) - err := m.rmClient.DeleteE2TInstance(e2tInstance.Address, ransToBeDissociated, ranAssociationList) + err := m.rmClient.DeleteE2TInstance(e2tInstance.Address, e2tInstance.AssociatedRanList) if err != nil { - _ = m.setStateToRoutingManagerFailure(e2tInstance) - m.logger.Errorf("#E2TAssociationManager.RemoveE2tInstance - RoutingManager failure: Failed to delete E2T %s. Error: %s", e2tInstance.Address, err) - return err + m.logger.Warnf("#E2TAssociationManager.RemoveE2tInstance - RoutingManager failure: Failed to delete E2T %s. Error: %s", e2tInstance.Address, err) + // log and continue } err = m.e2tInstanceManager.RemoveE2TInstance(e2tInstance.Address) @@ -117,23 +136,6 @@ func (m *E2TAssociationManager) RemoveE2tInstance(e2tInstance *entities.E2TInsta return err } - for e2tAddress, associatedRans := range ranAssociationList { - err = m.e2tInstanceManager.AddRansToInstance(e2tAddress, associatedRans) - if err != nil { - m.logger.Errorf("#E2TAssociationManager.RemoveE2tInstance - Failed to add RANs %s to E2T %s. Error: %s", associatedRans, e2tAddress, err) - return err - } - } - m.logger.Infof("#E2TAssociationManager.RemoveE2tInstance - E2T %s successfully removed.", e2tInstance.Address) return nil } - -func (m *E2TAssociationManager) setStateToRoutingManagerFailure(e2tInstance *entities.E2TInstance) error { - - err := m.e2tInstanceManager.SetE2tInstanceState(e2tInstance.Address, e2tInstance.State, entities.RoutingManagerFailure) - if err != nil { - return err - } - return nil -}