blob: 0e8ed7ef21ad917c6853c29c315c84412b7c6458 [file] [log] [blame]
//
// Copyright 2019 AT&T Intellectual Property
// Copyright 2019 Nokia
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// This source code is part of the near-RT RIC (RAN Intelligent Controller)
// platform project (RICP).
package managers
import (
"e2mgr/e2managererrors"
"e2mgr/logger"
"e2mgr/models"
"e2mgr/services"
"gerrit.o-ran-sc.org/r/ric-plt/nodeb-rnib.git/entities"
"github.com/pkg/errors"
)
type UpdateEnbManager struct {
logger *logger.Logger
rnibDataService services.RNibDataService
nodebValidator *NodebValidator
}
func NewUpdateEnbManager(logger *logger.Logger, rnibDataService services.RNibDataService, nodebValidator *NodebValidator) *UpdateEnbManager {
return &UpdateEnbManager{
logger: logger,
rnibDataService: rnibDataService,
nodebValidator: nodebValidator,
}
}
func (h *UpdateEnbManager) Validate(request models.Request) error {
updateEnbRequest := request.(*models.UpdateEnbRequest)
h.logger.Infof("#UpdateEnbManager.Validate - Validate incoming request, ran name: %s", updateEnbRequest.RanName)
if err := h.validateRequestBody(updateEnbRequest); err != nil {
h.logger.Errorf("#UpdateEnbManager.Validate - validation failure: %s is a mandatory field and cannot be empty", err)
return err
}
return nil
}
func (h *UpdateEnbManager) RemoveNodebCells(nodeb *entities.NodebInfo) error {
if nodeb.NodeType != entities.Node_ENB {
h.logger.Errorf("#UpdateEnbManager.RemoveNodebCells - RAN name: %s - RAN is not eNB.", nodeb.RanName)
return e2managererrors.NewRequestValidationError()
}
servedCells := nodeb.GetEnb().GetServedCells()
if len(servedCells) == 0 {
h.logger.Infof("#UpdateGnbManager.RemoveNodebCells - RAN name: %s - eNB cells are nil or empty - no cells to remove", nodeb.GetRanName())
return nil
}
err := h.rnibDataService.RemoveServedCells(nodeb.GetRanName(), servedCells)
if err != nil {
h.logger.Errorf("#UpdateEnbManager.RemoveNodebCells - RAN name: %s - Failed removing eNB served cells", nodeb.GetRanName())
return e2managererrors.NewRnibDbError()
}
h.logger.Infof("#UpdateEnbManager.RemoveNodebCells - RAN name: %s - Successfully removed eNB served cells", nodeb.GetRanName())
return nil
}
func (h *UpdateEnbManager) SetNodeb(nodeb *entities.NodebInfo, request models.Request) {
updateEnbRequest := request.(*models.UpdateEnbRequest)
if nodeb.SetupFromNetwork {
updateEnbRequest.Enb.EnbType = nodeb.GetEnb().GetEnbType()
}
nodeb.Configuration = &entities.NodebInfo_Enb{Enb: updateEnbRequest.Enb}
}
func (h *UpdateEnbManager) UpdateNodeb(nodeb *entities.NodebInfo) error {
err := h.rnibDataService.UpdateEnb(nodeb, nodeb.GetEnb().GetServedCells())
if err != nil {
h.logger.Errorf("#UpdateEnbManager.UpdateNodeb - RAN name: %s - Failed updating eNB. Error: %s", nodeb.GetRanName(), err)
return e2managererrors.NewRnibDbError()
}
h.logger.Infof("#UpdateEnbManager.UpdateNodeb - RAN name: %s - Successfully updated eNB", nodeb.GetRanName())
return nil
}
func (h *UpdateEnbManager) validateRequestBody(request *models.UpdateEnbRequest) error {
if request.Enb == nil {
return errors.New("enb")
}
if err := h.nodebValidator.IsEnbValid(request.Enb); err != nil {
return err
}
return nil
}
func (h *UpdateEnbManager) ValidateNodeb(nodeb *entities.NodebInfo) error{
enbType := nodeb.GetEnb().GetEnbType()
if h.nodebValidator.IsNgEnbType(enbType) {
h.logger.Errorf("#UpdateEnbManager.ValidateNodeb - validation failure: current enb type is not supported. enb type: %s", enbType)
return errors.New("")
}
return nil
}