X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=pkg%2Fcontrol%2Ftypes.go;h=5408f4878df9e6fc45f5e0e501abce77a5ebafa4;hb=d708a43badb0742684b22866977f14cc1c03a1ba;hp=83312d8b36d1e909b9de858f1f057527073a62ca;hpb=379ff082446038f3dee0f22d4f79c0965e9da25a;p=ric-plt%2Fsubmgr.git diff --git a/pkg/control/types.go b/pkg/control/types.go index 83312d8..5408f48 100644 --- a/pkg/control/types.go +++ b/pkg/control/types.go @@ -19,17 +19,135 @@ package control -type RmrDatagram struct { - MessageType int - SubscriptionId uint16 - Payload []byte +import ( + "gerrit.o-ran-sc.org/r/ric-plt/e2ap/pkg/e2ap" + "strconv" + "strings" +) + +//----------------------------------------------------------------------------- +// +//----------------------------------------------------------------------------- +type RequestId struct { + e2ap.RequestId +} + +func (rid *RequestId) String() string { + return "reqid(" + rid.RequestId.String() + ")" +} + +//----------------------------------------------------------------------------- +// +//----------------------------------------------------------------------------- +type RmrEndpoint struct { + Addr string // xapp addr + Port uint16 // xapp port +} + +func (endpoint RmrEndpoint) String() string { + return endpoint.Addr + ":" + strconv.FormatUint(uint64(endpoint.Port), 10) +} + +func (endpoint *RmrEndpoint) Equal(ep *RmrEndpoint) bool { + if (endpoint.Addr == ep.Addr) && + (endpoint.Port == ep.Port) { + return true + } + return false +} + +func (endpoint *RmrEndpoint) GetAddr() string { + return endpoint.Addr +} + +func (endpoint *RmrEndpoint) GetPort() uint16 { + return endpoint.Port +} + +func (endpoint *RmrEndpoint) Set(src string) bool { + elems := strings.Split(src, ":") + if len(elems) == 2 { + srcAddr := elems[0] + srcPort, err := strconv.ParseUint(elems[1], 10, 16) + if err == nil { + endpoint.Addr = srcAddr + endpoint.Port = uint16(srcPort) + return true + } + } + return false } -type SubRouteInfo struct { - Command Action - Address string - Port uint16 - SubID uint16 +//----------------------------------------------------------------------------- +// +//----------------------------------------------------------------------------- +type RmrEndpointList struct { + Endpoints []RmrEndpoint } -type Action int +func (eplist *RmrEndpointList) String() string { + valuesText := eplist.StringList() + return strings.Join(valuesText, ",") +} + +func (eplist *RmrEndpointList) StringList() []string { + tmpList := eplist.Endpoints + valuesText := []string{} + for i := range tmpList { + valuesText = append(valuesText, tmpList[i].String()) + } + return valuesText +} + +func (eplist *RmrEndpointList) Size() int { + return len(eplist.Endpoints) +} + +func (eplist *RmrEndpointList) AddEndpoint(ep *RmrEndpoint) bool { + for i := range eplist.Endpoints { + if eplist.Endpoints[i].Equal(ep) { + return false + } + } + eplist.Endpoints = append(eplist.Endpoints, *ep) + return true +} + +func (eplist *RmrEndpointList) DelEndpoint(ep *RmrEndpoint) bool { + for i := range eplist.Endpoints { + if eplist.Endpoints[i].Equal(ep) { + eplist.Endpoints[i] = eplist.Endpoints[len(eplist.Endpoints)-1] + eplist.Endpoints[len(eplist.Endpoints)-1] = RmrEndpoint{"", 0} + eplist.Endpoints = eplist.Endpoints[:len(eplist.Endpoints)-1] + return true + } + } + return false +} + +func (eplist *RmrEndpointList) DelEndpoints(otheplist *RmrEndpointList) bool { + var retval bool = false + for i := range otheplist.Endpoints { + if eplist.DelEndpoint(&otheplist.Endpoints[i]) { + retval = true + } + } + return retval +} + +func (eplist *RmrEndpointList) HasEndpoint(ep *RmrEndpoint) bool { + for i := range eplist.Endpoints { + if eplist.Endpoints[i].Equal(ep) { + return true + } + } + return false +} + +func NewRmrEndpoint(src string) *RmrEndpoint { + ep := &RmrEndpoint{} + if ep.Set(src) == false { + return nil + } + return ep +}