blob: e47ca836b734666d1e7e489c4a2a87fbf19021a1 [file] [log] [blame]
Balint Uveges871fa392019-04-02 20:31:11 +00001/*
2==================================================================================
3 Copyright (c) 2019 AT&T Intellectual Property.
4 Copyright (c) 2019 Nokia
5
6 Licensed under the Apache License, Version 2.0 (the "License");
7 you may not use this file except in compliance with the License.
8 You may obtain a copy of the License at
9
10 http://www.apache.org/licenses/LICENSE-2.0
11
12 Unless required by applicable law or agreed to in writing, software
13 distributed under the License is distributed on an "AS IS" BASIS,
14 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 See the License for the specific language governing permissions and
16 limitations under the License.
17==================================================================================
18*/
19/*
20 Mnemonic: rpe.go
21 Abstract: Contains RPE (Route Policy Engine) module definitions and generic RPE components
22 Date: 16 March 2019
23*/
24
25package rpe
26
27import (
28 "errors"
kalnagy92162652019-07-02 15:15:49 +020029 "routing-manager/pkg/rtmgr"
zkoczkaeb2ff0d2019-09-26 16:59:54 +020030 "routing-manager/pkg/sbi"
kalnagy92162652019-07-02 15:15:49 +020031 "strconv"
zkoczkadbb88b92019-10-17 10:34:38 +020032 "runtime"
Balint Uveges871fa392019-04-02 20:31:11 +000033)
34
35var (
zkoczkaaaf8d392019-10-02 17:16:06 +020036 SupportedRpes = []*EngineConfig{
37 {
kalnagy92162652019-07-02 15:15:49 +020038 Name: "rmrpush",
39 Version: "pubsush",
40 Protocol: "rmruta",
41 Instance: NewRmrPush(),
42 IsAvailable: true,
Balint Uveges871fa392019-04-02 20:31:11 +000043 },
44 }
45)
46
zkoczkaaaf8d392019-10-02 17:16:06 +020047func GetRpe(rpeName string) (Engine, error) {
Balint Uveges871fa392019-04-02 20:31:11 +000048 for _, rpe := range SupportedRpes {
kalnagy92162652019-07-02 15:15:49 +020049 if rpe.Name == rpeName && rpe.IsAvailable {
50 return rpe.Instance, nil
Balint Uveges871fa392019-04-02 20:31:11 +000051 }
52 }
Peter Szilagyi16d84d62019-04-24 14:51:02 +000053 return nil, errors.New("SBI:" + rpeName + " is not supported or still not a available")
Balint Uveges871fa392019-04-02 20:31:11 +000054}
55
kalnagy92162652019-07-02 15:15:49 +020056type Rpe struct {
57}
58
kalnagy92162652019-07-02 15:15:49 +020059func getEndpointByName(eps *rtmgr.Endpoints, name string) *rtmgr.Endpoint {
60 for _, ep := range *eps {
61 if ep.Name == name {
62 rtmgr.Logger.Debug("name: %s", ep.Name)
63 rtmgr.Logger.Debug("ep: %v", ep)
64 return ep
65 }
66 }
67 return nil
68}
69
zkoczkaeb2ff0d2019-09-26 16:59:54 +020070func getEndpointByUuid(uuid string) *rtmgr.Endpoint {
71 endPoints := rtmgr.Eps
72 for _, ep := range endPoints {
kalnagy92162652019-07-02 15:15:49 +020073 if ep.Uuid == uuid {
74 rtmgr.Logger.Debug("name: %s", ep.Uuid)
75 rtmgr.Logger.Debug("ep: %v", ep)
76 return ep
77 }
78 }
79 return nil
80}
kalnagy92162652019-07-02 15:15:49 +020081
zkoczkaaaf8d392019-10-02 17:16:06 +020082func (r *Rpe) addRoute(messageType string, tx *rtmgr.Endpoint, rx *rtmgr.Endpoint, routeTable *rtmgr.RouteTable, subId int32) {
zkoczkadbb88b92019-10-17 10:34:38 +020083 if tx != nil && rx != nil {
84 txList := rtmgr.EndpointList{*tx}
85 rxList := []rtmgr.EndpointList{[]rtmgr.Endpoint{*rx}}
86 messageId := rtmgr.MessageTypes[messageType]
87 route := rtmgr.RouteTableEntry{
88 MessageType: messageId,
89 TxList: txList,
90 RxGroups: rxList,
91 SubID: subId}
92 *routeTable = append(*routeTable, route)
93 rtmgr.Logger.Debug("Route added: MessageTyp: %v, Tx: %v, Rx: %v, SubId: %v", messageId, tx.Uuid, rx.Uuid, subId)
94 rtmgr.Logger.Trace("Route added: MessageTyp: %v, Tx: %v, Rx: %v, SubId: %v", messageId, tx, rx, subId)
95 } else {
96 pc,_,_,ok := runtime.Caller(1)
97 details := runtime.FuncForPC(pc)
98 if ok && details != nil {
99 rtmgr.Logger.Error("Route addition skipped: Either TX or RX endpoint not present. Caller function is %s", details.Name())
100 }
101 }
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200102}
103
zkoczkaaaf8d392019-10-02 17:16:06 +0200104func (r *Rpe) generateXappRoutes(xAppEp *rtmgr.Endpoint, e2TermEp *rtmgr.Endpoint, subManEp *rtmgr.Endpoint, routeTable *rtmgr.RouteTable) {
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200105 rtmgr.Logger.Debug("rpe.generateXappRoutes invoked")
zkoczkaaaf8d392019-10-02 17:16:06 +0200106 rtmgr.Logger.Debug("Endpoint: %v, xAppType: %v", xAppEp.Name, xAppEp.XAppType)
107 if xAppEp.XAppType != sbi.PlatformType && len(xAppEp.TxMessages) > 0 && len(xAppEp.RxMessages) > 0 {
108 //xApp -> Subscription Manager
109 r.addRoute("RIC_SUB_REQ", xAppEp, subManEp, routeTable, -1)
110 r.addRoute("RIC_SUB_DEL_REQ", xAppEp, subManEp, routeTable, -1)
111 //xApp -> E2 Termination
112 r.addRoute("RIC_CONTROL_REQ", xAppEp, e2TermEp, routeTable, -1)
zkoczkab95b0762019-10-29 13:05:48 +0100113 //E2 Termination -> xApp
114 r.addRoute("RIC_CONTROL_ACK", e2TermEp, xAppEp, routeTable, -1)
115 r.addRoute("RIC_CONTROL_FAILURE", e2TermEp, xAppEp, routeTable, -1)
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200116 }
117}
118
119func (r *Rpe) generateSubscriptionRoutes(e2TermEp *rtmgr.Endpoint, subManEp *rtmgr.Endpoint, routeTable *rtmgr.RouteTable) {
120 rtmgr.Logger.Debug("rpe.addSubscriptionRoutes invoked")
zkoczkaaaf8d392019-10-02 17:16:06 +0200121 subscriptionList := &rtmgr.Subs
122 for _, subscription := range *subscriptionList {
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200123 rtmgr.Logger.Debug("Subscription: %v", subscription)
124 xAppUuid := subscription.Fqdn + ":" + strconv.Itoa(int(subscription.Port))
125 rtmgr.Logger.Debug("xApp UUID: %v", xAppUuid)
126 xAppEp := getEndpointByUuid(xAppUuid)
127 //Subscription Manager -> xApp
zkoczkaaaf8d392019-10-02 17:16:06 +0200128 r.addRoute("RIC_SUB_RESP", subManEp, xAppEp, routeTable, subscription.SubID)
129 r.addRoute("RIC_SUB_FAILURE", subManEp, xAppEp, routeTable, subscription.SubID)
130 r.addRoute("RIC_SUB_DEL_RESP", subManEp, xAppEp, routeTable, subscription.SubID)
131 r.addRoute("RIC_SUB_DEL_FAILURE", subManEp, xAppEp, routeTable, subscription.SubID)
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200132 //E2 Termination -> xApp
zkoczkaaaf8d392019-10-02 17:16:06 +0200133 r.addRoute("RIC_INDICATION", e2TermEp, xAppEp, routeTable, subscription.SubID)
134 r.addRoute("RIC_CONTROL_ACK", e2TermEp, xAppEp, routeTable, subscription.SubID)
135 r.addRoute("RIC_CONTROL_FAILURE", e2TermEp, xAppEp, routeTable, subscription.SubID)
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200136 }
137}
138
prabhukaliswamybe9f2682019-11-22 07:24:09 +0000139func (r *Rpe) generatePlatformRoutes(e2TermEp *rtmgr.Endpoint, subManEp *rtmgr.Endpoint, e2ManEp *rtmgr.Endpoint, ueManEp *rtmgr.Endpoint, rsmEp *rtmgr.Endpoint, routeTable *rtmgr.RouteTable) {
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200140 rtmgr.Logger.Debug("rpe.generatePlatformRoutes invoked")
141 //Platform Routes --- Subscription Routes
142 //Subscription Manager -> E2 Termination
zkoczkaaaf8d392019-10-02 17:16:06 +0200143 r.addRoute("RIC_SUB_REQ", subManEp, e2TermEp, routeTable, -1)
144 r.addRoute("RIC_SUB_DEL_REQ", subManEp, e2TermEp, routeTable, -1)
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200145 //E2 Termination -> Subscription Manager
zkoczkaaaf8d392019-10-02 17:16:06 +0200146 r.addRoute("RIC_SUB_RESP", e2TermEp, subManEp, routeTable, -1)
147 r.addRoute("RIC_SUB_DEL_RESP", e2TermEp, subManEp, routeTable, -1)
148 r.addRoute("RIC_SUB_FAILURE", e2TermEp, subManEp, routeTable, -1)
149 r.addRoute("RIC_SUB_DEL_FAILURE", e2TermEp, subManEp, routeTable, -1)
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200150 //TODO: UE Man Routes removed (since it is not existing)
151 //UE Manager -> Subscription Manager
152 //r.addRoute("RIC_SUB_REQ", ueManEp, subManEp, routeTable)
153 //r.addRoute("RIC_SUB_DEL_REQ", ueManEp, subManEp, routeTable)
154 ////UE Manager -> E2 Termination
155 //r.addRoute("RIC_CONTROL_REQ", ueManEp, e2TermEp, routeTable)
156
157 //Platform Routes --- X2 Routes
158 //E2 Manager -> E2 Termination
zkoczkaaaf8d392019-10-02 17:16:06 +0200159 r.addRoute("RIC_X2_SETUP_REQ", e2ManEp, e2TermEp, routeTable, -1)
zkoczkab95b0762019-10-29 13:05:48 +0100160 r.addRoute("RIC_X2_RESET_REQ", e2ManEp, e2TermEp, routeTable, -1)
zkoczkaaaf8d392019-10-02 17:16:06 +0200161 r.addRoute("RIC_X2_RESET_RESP", e2ManEp, e2TermEp, routeTable, -1)
162 r.addRoute("RIC_ENDC_X2_SETUP_REQ", e2ManEp, e2TermEp, routeTable, -1)
zkoczka4d0e07a2019-10-15 15:05:57 +0200163 r.addRoute("RIC_SCTP_CLEAR_ALL", e2ManEp, e2TermEp, routeTable, -1)
zkoczkab95b0762019-10-29 13:05:48 +0100164 r.addRoute("RIC_ENB_CONF_UPDATE_ACK", e2ManEp, e2TermEp, routeTable, -1)
165 r.addRoute("RIC_ENB_CONF_UPDATE_FAILURE", e2ManEp, e2TermEp, routeTable, -1)
166 r.addRoute("RIC_ENDC_CONF_UPDATE_ACK", e2ManEp, e2TermEp, routeTable, -1)
167 r.addRoute("RIC_ENDC_CONF_UPDATE_FAILURE", e2ManEp, e2TermEp, routeTable, -1)
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200168 //E2 Termination -> E2 Manager
zkoczka4d0e07a2019-10-15 15:05:57 +0200169 r.addRoute("E2_TERM_INIT", e2TermEp, e2ManEp, routeTable, -1)
zkoczkaaaf8d392019-10-02 17:16:06 +0200170 r.addRoute("RIC_X2_SETUP_RESP", e2TermEp, e2ManEp, routeTable, -1)
zkoczka57d85402019-10-30 11:49:50 +0100171 r.addRoute("RIC_X2_SETUP_FAILURE", e2TermEp, e2ManEp, routeTable, -1)
zkoczkab95b0762019-10-29 13:05:48 +0100172 r.addRoute("RIC_X2_RESET_REQ", e2TermEp, e2ManEp, routeTable, -1)
zkoczkaaaf8d392019-10-02 17:16:06 +0200173 r.addRoute("RIC_X2_RESET_RESP", e2TermEp, e2ManEp, routeTable, -1)
zkoczka988d1da2019-10-29 11:09:26 +0100174 r.addRoute("RIC_ENDC_X2_SETUP_RESP", e2TermEp, e2ManEp, routeTable, -1)
175 r.addRoute("RIC_ENDC_X2_SETUP_FAILURE", e2TermEp, e2ManEp, routeTable, -1)
zkoczkab95b0762019-10-29 13:05:48 +0100176 r.addRoute("RIC_ENDC_CONF_UPDATE", e2TermEp, e2ManEp, routeTable, -1)
zkoczka4d0e07a2019-10-15 15:05:57 +0200177 r.addRoute("RIC_SCTP_CONNECTION_FAILURE", e2TermEp, e2ManEp, routeTable, -1)
zkoczkab95b0762019-10-29 13:05:48 +0100178 r.addRoute("RIC_ERROR_INDICATION", e2TermEp, e2ManEp, routeTable, -1)
179 r.addRoute("RIC_ENB_CONF_UPDATE", e2TermEp, e2ManEp, routeTable, -1)
180 r.addRoute("RIC_ENB_LOAD_INFORMATION", e2TermEp, e2ManEp, routeTable, -1)
prabhukaliswamybe9f2682019-11-22 07:24:09 +0000181 //E2 Manager -> Resource Status Manager
182 r.addRoute("RAN_CONNECTED", e2ManEp, rsmEp, routeTable, -1)
183 r.addRoute("RAN_RESTARTED", e2ManEp, rsmEp, routeTable, -1)
184 r.addRoute("RAN_RECONFIGURED", e2ManEp, rsmEp, routeTable, -1)
185 //Resource Status Manager -> E2 Termination
186 r.addRoute("RIC_RES_STATUS_REQ", rsmEp, e2TermEp, routeTable, -1)
187 //E2 Termination -> Resource Status Manager
188 r.addRoute("RIC_RES_STATUS_RESP", e2TermEp, rsmEp, routeTable, -1)
189 r.addRoute("RIC_RES_STATUS_FAILURE", e2TermEp, rsmEp, routeTable, -1)
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200190}
191
192func (r *Rpe) generateRouteTable(endPointList rtmgr.Endpoints) *rtmgr.RouteTable {
193 rtmgr.Logger.Debug("rpe.generateRouteTable invoked")
194 rtmgr.Logger.Debug("Endpoint List: %v", endPointList)
195 routeTable := &rtmgr.RouteTable{}
196 e2TermEp := getEndpointByName(&endPointList, "E2TERM")
197 if e2TermEp == nil {
198 rtmgr.Logger.Error("Platform component not found: %v", "E2 Termination")
199 rtmgr.Logger.Debug("Endpoints: %v", endPointList)
200 }
201 subManEp := getEndpointByName(&endPointList, "SUBMAN")
202 if subManEp == nil {
203 rtmgr.Logger.Error("Platform component not found: %v", "Subscription Manager")
204 rtmgr.Logger.Debug("Endpoints: %v", endPointList)
205 }
206 e2ManEp := getEndpointByName(&endPointList, "E2MAN")
207 if e2ManEp == nil {
208 rtmgr.Logger.Error("Platform component not found: %v", "E2 Manager")
209 rtmgr.Logger.Debug("Endpoints: %v", endPointList)
210 }
211 ueManEp := getEndpointByName(&endPointList, "UEMAN")
212 if ueManEp == nil {
213 rtmgr.Logger.Error("Platform component not found: %v", "UE Manger")
214 rtmgr.Logger.Debug("Endpoints: %v", endPointList)
215 }
prabhukaliswamybe9f2682019-11-22 07:24:09 +0000216 rsmEp := getEndpointByName(&endPointList, "RSM")
217 if rsmEp == nil {
218 rtmgr.Logger.Error("Platform component not found: %v", "Resource Status Manager")
219 rtmgr.Logger.Debug("Endpoints: %v", endPointList)
220 }
221 r.generatePlatformRoutes(e2TermEp, subManEp, e2ManEp, ueManEp, rsmEp, routeTable)
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200222
223 for _, endPoint := range endPointList {
224 rtmgr.Logger.Debug("Endpoint: %v, xAppType: %v", endPoint.Name, endPoint.XAppType)
zkoczkaaaf8d392019-10-02 17:16:06 +0200225 if endPoint.XAppType != sbi.PlatformType && len(endPoint.TxMessages) > 0 && len(endPoint.RxMessages) > 0 {
226 r.generateXappRoutes(endPoint, e2TermEp, subManEp, routeTable)
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200227 r.generateSubscriptionRoutes(e2TermEp, subManEp, routeTable)
228 }
229 }
230 return routeTable
kalnagy92162652019-07-02 15:15:49 +0200231}