blob: fcda8fe3828c263b5e67798b32a10b35f1f00dc4 [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"
Balint Uveges871fa392019-04-02 20:31:11 +000032)
33
34var (
zkoczkaaaf8d392019-10-02 17:16:06 +020035 SupportedRpes = []*EngineConfig{
36 {
kalnagy92162652019-07-02 15:15:49 +020037 Name: "rmrpush",
38 Version: "pubsush",
39 Protocol: "rmruta",
40 Instance: NewRmrPush(),
41 IsAvailable: true,
Balint Uveges871fa392019-04-02 20:31:11 +000042 },
43 }
44)
45
zkoczkaaaf8d392019-10-02 17:16:06 +020046func GetRpe(rpeName string) (Engine, error) {
Balint Uveges871fa392019-04-02 20:31:11 +000047 for _, rpe := range SupportedRpes {
kalnagy92162652019-07-02 15:15:49 +020048 if rpe.Name == rpeName && rpe.IsAvailable {
49 return rpe.Instance, nil
Balint Uveges871fa392019-04-02 20:31:11 +000050 }
51 }
Peter Szilagyi16d84d62019-04-24 14:51:02 +000052 return nil, errors.New("SBI:" + rpeName + " is not supported or still not a available")
Balint Uveges871fa392019-04-02 20:31:11 +000053}
54
kalnagy92162652019-07-02 15:15:49 +020055type Rpe struct {
56}
57
kalnagy92162652019-07-02 15:15:49 +020058func getEndpointByName(eps *rtmgr.Endpoints, name string) *rtmgr.Endpoint {
59 for _, ep := range *eps {
60 if ep.Name == name {
61 rtmgr.Logger.Debug("name: %s", ep.Name)
62 rtmgr.Logger.Debug("ep: %v", ep)
63 return ep
64 }
65 }
66 return nil
67}
68
zkoczkaeb2ff0d2019-09-26 16:59:54 +020069func getEndpointByUuid(uuid string) *rtmgr.Endpoint {
70 endPoints := rtmgr.Eps
71 for _, ep := range endPoints {
kalnagy92162652019-07-02 15:15:49 +020072 if ep.Uuid == uuid {
73 rtmgr.Logger.Debug("name: %s", ep.Uuid)
74 rtmgr.Logger.Debug("ep: %v", ep)
75 return ep
76 }
77 }
78 return nil
79}
kalnagy92162652019-07-02 15:15:49 +020080
zkoczkaaaf8d392019-10-02 17:16:06 +020081func (r *Rpe) addRoute(messageType string, tx *rtmgr.Endpoint, rx *rtmgr.Endpoint, routeTable *rtmgr.RouteTable, subId int32) {
zkoczkaeb2ff0d2019-09-26 16:59:54 +020082 txList := rtmgr.EndpointList{*tx}
83 rxList := []rtmgr.EndpointList{[]rtmgr.Endpoint{*rx}}
zkoczkaaaf8d392019-10-02 17:16:06 +020084 messageId := rtmgr.MessageTypes[messageType]
zkoczkaeb2ff0d2019-09-26 16:59:54 +020085 route := rtmgr.RouteTableEntry{
zkoczkaaaf8d392019-10-02 17:16:06 +020086 MessageType: messageId,
87 TxList: txList,
88 RxGroups: rxList,
89 SubID: subId}
zkoczkaeb2ff0d2019-09-26 16:59:54 +020090 *routeTable = append(*routeTable, route)
zkoczkaaaf8d392019-10-02 17:16:06 +020091 rtmgr.Logger.Debug("Route added: MessageTyp: %v, Tx: %v, Rx: %v, SubId: %v", messageId, tx.Uuid, rx.Uuid, subId)
92 rtmgr.Logger.Trace("Route added: MessageTyp: %v, Tx: %v, Rx: %v, SubId: %v", messageId, tx, rx, subId)
zkoczkaeb2ff0d2019-09-26 16:59:54 +020093}
94
zkoczkaaaf8d392019-10-02 17:16:06 +020095func (r *Rpe) generateXappRoutes(xAppEp *rtmgr.Endpoint, e2TermEp *rtmgr.Endpoint, subManEp *rtmgr.Endpoint, routeTable *rtmgr.RouteTable) {
zkoczkaeb2ff0d2019-09-26 16:59:54 +020096 rtmgr.Logger.Debug("rpe.generateXappRoutes invoked")
zkoczkaaaf8d392019-10-02 17:16:06 +020097 rtmgr.Logger.Debug("Endpoint: %v, xAppType: %v", xAppEp.Name, xAppEp.XAppType)
98 if xAppEp.XAppType != sbi.PlatformType && len(xAppEp.TxMessages) > 0 && len(xAppEp.RxMessages) > 0 {
99 //xApp -> Subscription Manager
100 r.addRoute("RIC_SUB_REQ", xAppEp, subManEp, routeTable, -1)
101 r.addRoute("RIC_SUB_DEL_REQ", xAppEp, subManEp, routeTable, -1)
102 //xApp -> E2 Termination
103 r.addRoute("RIC_CONTROL_REQ", xAppEp, e2TermEp, routeTable, -1)
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200104 }
105}
106
107func (r *Rpe) generateSubscriptionRoutes(e2TermEp *rtmgr.Endpoint, subManEp *rtmgr.Endpoint, routeTable *rtmgr.RouteTable) {
108 rtmgr.Logger.Debug("rpe.addSubscriptionRoutes invoked")
zkoczkaaaf8d392019-10-02 17:16:06 +0200109 subscriptionList := &rtmgr.Subs
110 for _, subscription := range *subscriptionList {
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200111 rtmgr.Logger.Debug("Subscription: %v", subscription)
112 xAppUuid := subscription.Fqdn + ":" + strconv.Itoa(int(subscription.Port))
113 rtmgr.Logger.Debug("xApp UUID: %v", xAppUuid)
114 xAppEp := getEndpointByUuid(xAppUuid)
115 //Subscription Manager -> xApp
zkoczkaaaf8d392019-10-02 17:16:06 +0200116 r.addRoute("RIC_SUB_RESP", subManEp, xAppEp, routeTable, subscription.SubID)
117 r.addRoute("RIC_SUB_FAILURE", subManEp, xAppEp, routeTable, subscription.SubID)
118 r.addRoute("RIC_SUB_DEL_RESP", subManEp, xAppEp, routeTable, subscription.SubID)
119 r.addRoute("RIC_SUB_DEL_FAILURE", subManEp, xAppEp, routeTable, subscription.SubID)
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200120 //E2 Termination -> xApp
zkoczkaaaf8d392019-10-02 17:16:06 +0200121 r.addRoute("RIC_INDICATION", e2TermEp, xAppEp, routeTable, subscription.SubID)
122 r.addRoute("RIC_CONTROL_ACK", e2TermEp, xAppEp, routeTable, subscription.SubID)
123 r.addRoute("RIC_CONTROL_FAILURE", e2TermEp, xAppEp, routeTable, subscription.SubID)
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200124 }
125}
126
127func (r *Rpe) generatePlatformRoutes(e2TermEp *rtmgr.Endpoint, subManEp *rtmgr.Endpoint, e2ManEp *rtmgr.Endpoint, ueManEp *rtmgr.Endpoint, routeTable *rtmgr.RouteTable) {
128 rtmgr.Logger.Debug("rpe.generatePlatformRoutes invoked")
129 //Platform Routes --- Subscription Routes
130 //Subscription Manager -> E2 Termination
zkoczkaaaf8d392019-10-02 17:16:06 +0200131 r.addRoute("RIC_SUB_REQ", subManEp, e2TermEp, routeTable, -1)
132 r.addRoute("RIC_SUB_DEL_REQ", subManEp, e2TermEp, routeTable, -1)
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200133 //E2 Termination -> Subscription Manager
zkoczkaaaf8d392019-10-02 17:16:06 +0200134 r.addRoute("RIC_SUB_RESP", e2TermEp, subManEp, routeTable, -1)
135 r.addRoute("RIC_SUB_DEL_RESP", e2TermEp, subManEp, routeTable, -1)
136 r.addRoute("RIC_SUB_FAILURE", e2TermEp, subManEp, routeTable, -1)
137 r.addRoute("RIC_SUB_DEL_FAILURE", e2TermEp, subManEp, routeTable, -1)
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200138 //TODO: UE Man Routes removed (since it is not existing)
139 //UE Manager -> Subscription Manager
140 //r.addRoute("RIC_SUB_REQ", ueManEp, subManEp, routeTable)
141 //r.addRoute("RIC_SUB_DEL_REQ", ueManEp, subManEp, routeTable)
142 ////UE Manager -> E2 Termination
143 //r.addRoute("RIC_CONTROL_REQ", ueManEp, e2TermEp, routeTable)
144
145 //Platform Routes --- X2 Routes
146 //E2 Manager -> E2 Termination
zkoczkaaaf8d392019-10-02 17:16:06 +0200147 r.addRoute("RIC_X2_SETUP_REQ", e2ManEp, e2TermEp, routeTable, -1)
148 r.addRoute("RIC_X2_SETUP_RESP", e2ManEp, e2TermEp, routeTable, -1)
149 r.addRoute("RIC_X2_SETUP_FAILURE", e2ManEp, e2TermEp, routeTable, -1)
150 r.addRoute("RIC_X2_RESET_RESP", e2ManEp, e2TermEp, routeTable, -1)
151 r.addRoute("RIC_ENDC_X2_SETUP_REQ", e2ManEp, e2TermEp, routeTable, -1)
152 r.addRoute("RIC_ENDC_X2_SETUP_RESP", e2ManEp, e2TermEp, routeTable, -1)
153 r.addRoute("RIC_ENDC_X2_SETUP_FAILURE", e2ManEp, e2TermEp, routeTable, -1)
zkoczka4d0e07a2019-10-15 15:05:57 +0200154 r.addRoute("RIC_SCTP_CLEAR_ALL", e2ManEp, e2TermEp, routeTable, -1)
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200155 //E2 Termination -> E2 Manager
zkoczka4d0e07a2019-10-15 15:05:57 +0200156 r.addRoute("E2_TERM_INIT", e2TermEp, e2ManEp, routeTable, -1)
zkoczkaaaf8d392019-10-02 17:16:06 +0200157 r.addRoute("RIC_X2_SETUP_REQ", e2TermEp, e2ManEp, routeTable, -1)
158 r.addRoute("RIC_X2_SETUP_RESP", e2TermEp, e2ManEp, routeTable, -1)
159 r.addRoute("RIC_X2_RESET", e2TermEp, e2ManEp, routeTable, -1)
160 r.addRoute("RIC_X2_RESOURCE_STATUS_RESPONSE", e2TermEp, e2ManEp, routeTable, -1)
161 r.addRoute("RIC_X2_RESET_RESP", e2TermEp, e2ManEp, routeTable, -1)
162 r.addRoute("RIC_ENDC_X2_SETUP_REQ", e2ManEp, e2TermEp, routeTable, -1)
163 r.addRoute("RIC_ENDC_X2_SETUP_RESP", e2ManEp, e2TermEp, routeTable, -1)
164 r.addRoute("RIC_ENDC_X2_SETUP_FAILURE", e2ManEp, e2TermEp, routeTable, -1)
zkoczka4d0e07a2019-10-15 15:05:57 +0200165 r.addRoute("RIC_SCTP_CONNECTION_FAILURE", e2TermEp, e2ManEp, routeTable, -1)
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200166}
167
168func (r *Rpe) generateRouteTable(endPointList rtmgr.Endpoints) *rtmgr.RouteTable {
169 rtmgr.Logger.Debug("rpe.generateRouteTable invoked")
170 rtmgr.Logger.Debug("Endpoint List: %v", endPointList)
171 routeTable := &rtmgr.RouteTable{}
172 e2TermEp := getEndpointByName(&endPointList, "E2TERM")
173 if e2TermEp == nil {
174 rtmgr.Logger.Error("Platform component not found: %v", "E2 Termination")
175 rtmgr.Logger.Debug("Endpoints: %v", endPointList)
176 }
177 subManEp := getEndpointByName(&endPointList, "SUBMAN")
178 if subManEp == nil {
179 rtmgr.Logger.Error("Platform component not found: %v", "Subscription Manager")
180 rtmgr.Logger.Debug("Endpoints: %v", endPointList)
181 }
182 e2ManEp := getEndpointByName(&endPointList, "E2MAN")
183 if e2ManEp == nil {
184 rtmgr.Logger.Error("Platform component not found: %v", "E2 Manager")
185 rtmgr.Logger.Debug("Endpoints: %v", endPointList)
186 }
187 ueManEp := getEndpointByName(&endPointList, "UEMAN")
188 if ueManEp == nil {
189 rtmgr.Logger.Error("Platform component not found: %v", "UE Manger")
190 rtmgr.Logger.Debug("Endpoints: %v", endPointList)
191 }
192 r.generatePlatformRoutes(e2TermEp, subManEp, e2ManEp, ueManEp, routeTable)
193
194 for _, endPoint := range endPointList {
195 rtmgr.Logger.Debug("Endpoint: %v, xAppType: %v", endPoint.Name, endPoint.XAppType)
zkoczkaaaf8d392019-10-02 17:16:06 +0200196 if endPoint.XAppType != sbi.PlatformType && len(endPoint.TxMessages) > 0 && len(endPoint.RxMessages) > 0 {
197 r.generateXappRoutes(endPoint, e2TermEp, subManEp, routeTable)
zkoczkaeb2ff0d2019-09-26 16:59:54 +0200198 r.generateSubscriptionRoutes(e2TermEp, subManEp, routeTable)
199 }
200 }
201 return routeTable
kalnagy92162652019-07-02 15:15:49 +0200202}