X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=pkg%2Fcontrol%2Ftypes.go;h=00674c71023de37ba3e11dc118b9a0508727c64a;hb=63284a2eed02f5bfec0a237f83aae95adc702c43;hp=83312d8b36d1e909b9de858f1f057527073a62ca;hpb=379ff082446038f3dee0f22d4f79c0965e9da25a;p=ric-plt%2Fsubmgr.git diff --git a/pkg/control/types.go b/pkg/control/types.go index 83312d8..00674c7 100644 --- a/pkg/control/types.go +++ b/pkg/control/types.go @@ -19,12 +19,26 @@ package control +import ( + "bytes" + "fmt" + "gerrit.o-ran-sc.org/r/ric-plt/xapp-frame/pkg/xapp" + "strconv" + "strings" +) + +//----------------------------------------------------------------------------- +// +//----------------------------------------------------------------------------- type RmrDatagram struct { MessageType int SubscriptionId uint16 Payload []byte } +//----------------------------------------------------------------------------- +// +//----------------------------------------------------------------------------- type SubRouteInfo struct { Command Action Address string @@ -32,4 +46,80 @@ type SubRouteInfo struct { SubID uint16 } +//----------------------------------------------------------------------------- +// +//----------------------------------------------------------------------------- +type RmrEndpoint struct { + Addr string // xapp addr + Port uint16 // xapp port +} + +func (endpoint RmrEndpoint) String() string { + return endpoint.Get() +} + +func (endpoint *RmrEndpoint) GetAddr() string { + return endpoint.Addr +} + +func (endpoint *RmrEndpoint) GetPort() uint16 { + return endpoint.Port +} + +func (endpoint *RmrEndpoint) Get() string { + return endpoint.Addr + ":" + strconv.FormatUint(uint64(endpoint.Port), 10) +} + +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 +} + +func NewRmrEndpoint(src string) *RmrEndpoint { + ep := &RmrEndpoint{} + if ep.Set(src) == false { + return nil + } + return ep +} + +//----------------------------------------------------------------------------- +// +//----------------------------------------------------------------------------- type Action int + +func (act Action) String() string { + actions := [...]string{ + "CREATE", + "MERGE", + "NONE", + "DELETE", + } + + if act < CREATE || act > DELETE { + return "UNKNOWN" + } + return actions[act] +} + +//----------------------------------------------------------------------------- +// To add own method for rmrparams +//----------------------------------------------------------------------------- +type RMRParams struct { + *xapp.RMRParams +} + +func (params *RMRParams) String() string { + var b bytes.Buffer + fmt.Fprintf(&b, "Src=%s Mtype=%s(%d) SubId=%v Xid=%s Meid=%v", params.Src, xapp.RicMessageTypeToName[params.Mtype], params.Mtype, params.SubId, params.Xid, params.Meid) + return b.String() +}