package rpe
-import "rtmgr"
+import (
+ "routing-manager/pkg/rtmgr"
+ "strconv"
+)
+
+type Rmr struct {
+ Rpe
+}
+
+type RmrPush struct {
+ Rmr
+}
+
+func NewRmrPush() *RmrPush {
+ instance := new(RmrPush)
+ return instance
+}
/*
Produces the raw route message consumable by RMR
*/
-func generateRMRPolicies(xapps *[]rtmgr.XApp) *[]string {
- rtmgr.Logger.Debug("Invoked rmr.generateRMRPolicies")
- rtmgr.Logger.Debug("args: %v", (*xapps))
- key := "00000 "
+func (r *Rmr) generateRMRPolicies(eps rtmgr.Endpoints, key string) *[]string {
rawrt := []string{key + "newrt|start\n"}
- rt := getRouteTable(xapps)
+ rt := r.generateRouteTable(eps)
for _, rte := range *rt {
- rawrte := key + "rte|" + rte.MessageType
+ rawrte := key + "mse|" + rte.MessageType
for _, tx := range rte.TxList {
- rawrte += "," + tx.IpSocket
+ rawrte += "," + tx.Ip + ":" + strconv.Itoa(int(tx.Port))
}
- rawrte += "|"
+ rawrte += "|" + strconv.Itoa(int(rte.SubID)) + "|"
group := ""
for _, rxg := range rte.RxGroups {
member := ""
for _, rx := range rxg {
if member == "" {
- member += rx.IpSocket
+ member += rx.Ip + ":" + strconv.Itoa(int(rx.Port))
} else {
- member += "," + rx.IpSocket
+ member += "," + rx.Ip + ":" + strconv.Itoa(int(rx.Port))
}
}
if group == "" {
rawrt = append(rawrt, rawrte+"\n")
}
rawrt = append(rawrt, key+"newrt|end\n")
- rtmgr.Logger.Debug("rmr.generateRMRPolicies returns: %v", rawrt)
+ rtmgr.Logger.Debug("rmr.GeneratePolicies returns: %v", rawrt)
return &rawrt
}
+
+func (r *RmrPush) GeneratePolicies(eps rtmgr.Endpoints) *[]string {
+ rtmgr.Logger.Debug("Invoked rmr.GeneratePolicies, args: %v: ", eps)
+ return r.generateRMRPolicies(eps, "")
+}
+
+func (r *RmrPush) GenerateRouteTable(eps rtmgr.Endpoints) *rtmgr.RouteTable {
+ return r.generateRouteTable(eps)
+}