X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=E2Manager%2Fmanagers%2Fe2t_association_manager.go;h=8ed5ec1acfe7c83196919f8e411e3db8f37871f6;hb=refs%2Fchanges%2F62%2F4162%2F1;hp=8958241e07661c49c4d4d9bd647f3e22736343f7;hpb=3ae760f4378ea43575eca6e83ccc01084566e7cf;p=ric-plt%2Fe2mgr.git diff --git a/E2Manager/managers/e2t_association_manager.go b/E2Manager/managers/e2t_association_manager.go index 8958241..8ed5ec1 100644 --- a/E2Manager/managers/e2t_association_manager.go +++ b/E2Manager/managers/e2t_association_manager.go @@ -28,18 +28,20 @@ import ( ) 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, } } @@ -64,23 +66,27 @@ func (m *E2TAssociationManager) AssociateRan(e2tAddress string, nodebInfo *entit 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 + _ = m.ranConnectStatusChangeManager.ChangeStatus(nodebInfo, entities.ConnectionStatus_DISCONNECTED) + return e2managererrors.NewRoutingManagerError() } - 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) + + rnibErr := m.ranConnectStatusChangeManager.ChangeStatus(nodebInfo, entities.ConnectionStatus_CONNECTED) + + if rnibErr != nil { + return e2managererrors.NewRnibDbError() } - var err error - if rmErr != nil { - err = e2managererrors.NewRoutingManagerError() - } else if rNibErr != nil{ - err = e2managererrors.NewRnibDbError() + + 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 e2managererrors.NewRnibDbError() } - return err + + return nil } func (m *E2TAssociationManager) DissociateRan(e2tAddress string, ranName string) error {