This design matches the requirements in the following USs:
- RIC-431Getting issue details... STATUS
- RIC-432Getting issue details... STATUS
- RIC-433Getting issue details... STATUS
- RIC-434Getting issue details... STATUS
RnibReader changes
We shall modify the ServedCellInfo message inside the Enb proto message:
Current enb.proto:
message Enb { EnbType enb_type = 1; repeated ServedCellInfo served_cells = 2; repeated string gu_group_ids = 3; } message ServedCellInfo { uint32 pci = 1; string cell_id = 2; string tac = 3; repeated string broadcast_plmns = 4; ChoiceEUTRAMode choice_eutra_mode = 5; Eutra.Mode eutra_mode = 6; NumberOfAntennaPorts number_of_antenna_ports = 7; PrachConfiguration prach_configuration = 8; repeated MbsfnSubframe mbsfn_subframe_infos = 9; string csg_id = 10; repeated string mbms_service_area_identities = 11; repeated uint32 multiband_infos = 12; FreqBandIndicatorPriority freq_band_indicator_priority = 13; BandwidthReducedSI bandwidth_reduced_si = 14; repeated NeighbourInformation neighbour_infos = 15; }
Now, ServedCellInfo message is expanded by adding the AdditionalCellInformation message:
message ServedCellInfo { ... AdditionalCellInformation additional_cell_information = 16; } message AdditionalCellInformation { float cell_latitude = 1; float cell_longitude = 2; float antenna_height = 3; float antenna_azimuth_direction = 4; float antenna_tilt_angle = 5; float antenna_max_transmit = 6; float antenna_max_gain = 7; uint32 sector_id = 8; }
E2 Manager Changes
Configuration
Add a new configuration key to the yaml file.
Recently we've added:
stateChangeMessageChannel: RAN_CONNECTION_STATUS_CHANGE
Now we shall add a new channel for RAN changes:
ranManipulationMessageChannel: RAN_MANIPULATION
This key, as others, should be read to the app's configuration which is injected to various flows.
This key will be used by RnibWriter for adding/updating/deleting eNBs and updating gNBs.
RnibWriter will trigger Sdl.SetAndPublish method, sending the RAN_MANIPULATION channel, and one of the following events:
<RAN_NAME>_ADDED
<RAN_NAME>_UPDATED
<RAN_NAME>_DELETED
RnibWriter
- Modify the following method:
SaveNodeb(nbIdentity *entities.NbIdentity, nodebInfo *entities.NodebInfo) error
For Gnb type, we execute sdl's Set method.
For Enb type, we execute sdl's SetAndPublish method instead, sending RAN_MANIPULATION channel and <RAN_NAME>_ADDED event.
- Add the following methods:
RemoveServedCells(inventoryName string, servedCells []*entities.ServedCellInfo) error UpdateEnb(nodebInfo *entities.NodebInfo, servedCells []*entities.ServedCellInfo) error DeleteEnb(nodebInfo *entities.NodebInfo) error
Add eNB REST API
Agenda
POST /v1/nodeb/enb
is triggered, request body is validated- Execute
GetNodeb
with RAN name coming from the request.- If we have a DB error or if it already exists → error
- Create a NodebInfo struct with an Enb configuration, populate it with the request data and set its connection status to DISCONNECTED
- Execute
SaveNodeb
, wheresdl.SetAndPublish
will be triggered for eNB type, sending the RAN_MANIPULATION channel and the <RAN_NAME>_ADDED event. - Return 201 CREATED with NodebInfo response.
POST /v1/nodeb/enb
{ "ranName": "", "globalNbId": { plmnId: "", nbId: "" }, "ip": "", "port": 1234, "enb": { "enbType": "", "servedCells": [{}], "guGroupIds": [""] } }
Sequence Diagram
Update eNB REST API
Agenda
PUT /v1/nodeb/enb/<RAN_NAME>
is triggered, request body is validated- Execute
GetNodeb
with RAN name coming from the request.- If we have a DB error or if it doesn't exist → error
- Execute
RemoveServedCells
to remove the existing eNB cells - Set the nodeb with the request's data
- Execute
UpdateEnb
:- Set cells in both Cell ID key & PCI key
- Set nodeb in both RAN ID key & RAN NAME key
- Execute
sdl.SetAndPublish
, sending the RAN_MANIPULATION channel and the <RAN_NAME>_UPDATED event.
- Return 200 OK with NodebInfo response.
PUT /v1/nodeb/enb/<RAN_NAME>
{ "enb": { "enbType": "", "servedCells": [{}], "guGroupIds": [""] } }
Sequence Diagram
Delete eNB REST API
Agenda
DELETE /v1/nodeb/enb/<RAN_NAME>
is triggered.- Execute
GetNodeb
with RAN name coming from the request.- If we have a DB error or if it doesn't exist → error
- Execute
RemoveEnb
- Remove cells from both Cell ID key & PCI key (call RemoveServedCells)
- Remove nodeb from both RAN ID key & RAN NAME key
- Execute sdl.SetAndPublish(data,"RAN_MANIPULATION", "<RAN_NAME>_DELETED")
- Return 204 NO CONTENT response.
DELETE /v1/nodeb/enb/<RAN_NAME>
Sequence Diagram