From 58da9ac6e691a8c660eb8ca838a154e11da0db68 Mon Sep 17 00:00:00 2001 From: Ondrej Fabry Date: Wed, 22 Jul 2020 04:40:55 +0200 Subject: Fix binapigen decoding and minor improvements - fixed allocating byte slices before copying decoded data - simplified encoding functions - several minor improvements Change-Id: I6669424b89eb86333805cb1b57e4551169980cc2 Signed-off-by: Ondrej Fabry --- internal/testbinapi/binapi2001/syslog/syslog.ba.go | 959 +++++++++++++++++++++ .../testbinapi/binapi2001/syslog/syslog_rpc.ba.go | 60 ++ 2 files changed, 1019 insertions(+) create mode 100644 internal/testbinapi/binapi2001/syslog/syslog.ba.go create mode 100644 internal/testbinapi/binapi2001/syslog/syslog_rpc.ba.go (limited to 'internal/testbinapi/binapi2001/syslog') diff --git a/internal/testbinapi/binapi2001/syslog/syslog.ba.go b/internal/testbinapi/binapi2001/syslog/syslog.ba.go new file mode 100644 index 0000000..c9fd0f7 --- /dev/null +++ b/internal/testbinapi/binapi2001/syslog/syslog.ba.go @@ -0,0 +1,959 @@ +// Code generated by GoVPP's binapi-generator. DO NOT EDIT. +// versions: +// binapi-generator: v0.4.0-dev +// VPP: 20.01 +// source: .vppapi/core/syslog.api.json + +// Package syslog contains generated bindings for API file syslog.api. +// +// Contents: +// 5 aliases +// 5 enums +// 6 structs +// 1 union +// 8 messages +// +package syslog + +import ( + "fmt" + api "git.fd.io/govpp.git/api" + codec "git.fd.io/govpp.git/codec" + "net" + "strconv" + "strings" +) + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the GoVPP api package it is being compiled against. +// A compilation error at this line likely means your copy of the +// GoVPP api package needs to be updated. +const _ = api.GoVppAPIPackageIsVersion2 + +const ( + APIFile = "syslog" + APIVersion = "1.0.0" + VersionCrc = 0xb0790f43 +) + +// AddressFamily defines enum 'address_family'. +type AddressFamily uint32 + +const ( + ADDRESS_IP4 AddressFamily = 0 + ADDRESS_IP6 AddressFamily = 1 +) + +var ( + AddressFamily_name = map[uint32]string{ + 0: "ADDRESS_IP4", + 1: "ADDRESS_IP6", + } + AddressFamily_value = map[string]uint32{ + "ADDRESS_IP4": 0, + "ADDRESS_IP6": 1, + } +) + +func (x AddressFamily) String() string { + s, ok := AddressFamily_name[uint32(x)] + if ok { + return s + } + return "AddressFamily(" + strconv.Itoa(int(x)) + ")" +} + +// IPDscp defines enum 'ip_dscp'. +type IPDscp uint8 + +const ( + IP_API_DSCP_CS0 IPDscp = 0 + IP_API_DSCP_CS1 IPDscp = 8 + IP_API_DSCP_AF11 IPDscp = 10 + IP_API_DSCP_AF12 IPDscp = 12 + IP_API_DSCP_AF13 IPDscp = 14 + IP_API_DSCP_CS2 IPDscp = 16 + IP_API_DSCP_AF21 IPDscp = 18 + IP_API_DSCP_AF22 IPDscp = 20 + IP_API_DSCP_AF23 IPDscp = 22 + IP_API_DSCP_CS3 IPDscp = 24 + IP_API_DSCP_AF31 IPDscp = 26 + IP_API_DSCP_AF32 IPDscp = 28 + IP_API_DSCP_AF33 IPDscp = 30 + IP_API_DSCP_CS4 IPDscp = 32 + IP_API_DSCP_AF41 IPDscp = 34 + IP_API_DSCP_AF42 IPDscp = 36 + IP_API_DSCP_AF43 IPDscp = 38 + IP_API_DSCP_CS5 IPDscp = 40 + IP_API_DSCP_EF IPDscp = 46 + IP_API_DSCP_CS6 IPDscp = 48 + IP_API_DSCP_CS7 IPDscp = 50 +) + +var ( + IPDscp_name = map[uint8]string{ + 0: "IP_API_DSCP_CS0", + 8: "IP_API_DSCP_CS1", + 10: "IP_API_DSCP_AF11", + 12: "IP_API_DSCP_AF12", + 14: "IP_API_DSCP_AF13", + 16: "IP_API_DSCP_CS2", + 18: "IP_API_DSCP_AF21", + 20: "IP_API_DSCP_AF22", + 22: "IP_API_DSCP_AF23", + 24: "IP_API_DSCP_CS3", + 26: "IP_API_DSCP_AF31", + 28: "IP_API_DSCP_AF32", + 30: "IP_API_DSCP_AF33", + 32: "IP_API_DSCP_CS4", + 34: "IP_API_DSCP_AF41", + 36: "IP_API_DSCP_AF42", + 38: "IP_API_DSCP_AF43", + 40: "IP_API_DSCP_CS5", + 46: "IP_API_DSCP_EF", + 48: "IP_API_DSCP_CS6", + 50: "IP_API_DSCP_CS7", + } + IPDscp_value = map[string]uint8{ + "IP_API_DSCP_CS0": 0, + "IP_API_DSCP_CS1": 8, + "IP_API_DSCP_AF11": 10, + "IP_API_DSCP_AF12": 12, + "IP_API_DSCP_AF13": 14, + "IP_API_DSCP_CS2": 16, + "IP_API_DSCP_AF21": 18, + "IP_API_DSCP_AF22": 20, + "IP_API_DSCP_AF23": 22, + "IP_API_DSCP_CS3": 24, + "IP_API_DSCP_AF31": 26, + "IP_API_DSCP_AF32": 28, + "IP_API_DSCP_AF33": 30, + "IP_API_DSCP_CS4": 32, + "IP_API_DSCP_AF41": 34, + "IP_API_DSCP_AF42": 36, + "IP_API_DSCP_AF43": 38, + "IP_API_DSCP_CS5": 40, + "IP_API_DSCP_EF": 46, + "IP_API_DSCP_CS6": 48, + "IP_API_DSCP_CS7": 50, + } +) + +func (x IPDscp) String() string { + s, ok := IPDscp_name[uint8(x)] + if ok { + return s + } + return "IPDscp(" + strconv.Itoa(int(x)) + ")" +} + +// IPEcn defines enum 'ip_ecn'. +type IPEcn uint8 + +const ( + IP_API_ECN_NONE IPEcn = 0 + IP_API_ECN_ECT0 IPEcn = 1 + IP_API_ECN_ECT1 IPEcn = 2 + IP_API_ECN_CE IPEcn = 3 +) + +var ( + IPEcn_name = map[uint8]string{ + 0: "IP_API_ECN_NONE", + 1: "IP_API_ECN_ECT0", + 2: "IP_API_ECN_ECT1", + 3: "IP_API_ECN_CE", + } + IPEcn_value = map[string]uint8{ + "IP_API_ECN_NONE": 0, + "IP_API_ECN_ECT0": 1, + "IP_API_ECN_ECT1": 2, + "IP_API_ECN_CE": 3, + } +) + +func (x IPEcn) String() string { + s, ok := IPEcn_name[uint8(x)] + if ok { + return s + } + return "IPEcn(" + strconv.Itoa(int(x)) + ")" +} + +// IPProto defines enum 'ip_proto'. +type IPProto uint32 + +const ( + IP_API_PROTO_HOPOPT IPProto = 0 + IP_API_PROTO_ICMP IPProto = 1 + IP_API_PROTO_IGMP IPProto = 2 + IP_API_PROTO_TCP IPProto = 6 + IP_API_PROTO_UDP IPProto = 17 + IP_API_PROTO_GRE IPProto = 47 + IP_API_PROTO_AH IPProto = 50 + IP_API_PROTO_ESP IPProto = 51 + IP_API_PROTO_EIGRP IPProto = 88 + IP_API_PROTO_OSPF IPProto = 89 + IP_API_PROTO_SCTP IPProto = 132 + IP_API_PROTO_RESERVED IPProto = 255 +) + +var ( + IPProto_name = map[uint32]string{ + 0: "IP_API_PROTO_HOPOPT", + 1: "IP_API_PROTO_ICMP", + 2: "IP_API_PROTO_IGMP", + 6: "IP_API_PROTO_TCP", + 17: "IP_API_PROTO_UDP", + 47: "IP_API_PROTO_GRE", + 50: "IP_API_PROTO_AH", + 51: "IP_API_PROTO_ESP", + 88: "IP_API_PROTO_EIGRP", + 89: "IP_API_PROTO_OSPF", + 132: "IP_API_PROTO_SCTP", + 255: "IP_API_PROTO_RESERVED", + } + IPProto_value = map[string]uint32{ + "IP_API_PROTO_HOPOPT": 0, + "IP_API_PROTO_ICMP": 1, + "IP_API_PROTO_IGMP": 2, + "IP_API_PROTO_TCP": 6, + "IP_API_PROTO_UDP": 17, + "IP_API_PROTO_GRE": 47, + "IP_API_PROTO_AH": 50, + "IP_API_PROTO_ESP": 51, + "IP_API_PROTO_EIGRP": 88, + "IP_API_PROTO_OSPF": 89, + "IP_API_PROTO_SCTP": 132, + "IP_API_PROTO_RESERVED": 255, + } +) + +func (x IPProto) String() string { + s, ok := IPProto_name[uint32(x)] + if ok { + return s + } + return "IPProto(" + strconv.Itoa(int(x)) + ")" +} + +// SyslogSeverity defines enum 'syslog_severity'. +type SyslogSeverity uint32 + +const ( + SYSLOG_API_SEVERITY_EMERG SyslogSeverity = 0 + SYSLOG_API_SEVERITY_ALERT SyslogSeverity = 1 + SYSLOG_API_SEVERITY_CRIT SyslogSeverity = 2 + SYSLOG_API_SEVERITY_ERR SyslogSeverity = 3 + SYSLOG_API_SEVERITY_WARN SyslogSeverity = 4 + SYSLOG_API_SEVERITY_NOTICE SyslogSeverity = 5 + SYSLOG_API_SEVERITY_INFO SyslogSeverity = 6 + SYSLOG_API_SEVERITY_DBG SyslogSeverity = 7 +) + +var ( + SyslogSeverity_name = map[uint32]string{ + 0: "SYSLOG_API_SEVERITY_EMERG", + 1: "SYSLOG_API_SEVERITY_ALERT", + 2: "SYSLOG_API_SEVERITY_CRIT", + 3: "SYSLOG_API_SEVERITY_ERR", + 4: "SYSLOG_API_SEVERITY_WARN", + 5: "SYSLOG_API_SEVERITY_NOTICE", + 6: "SYSLOG_API_SEVERITY_INFO", + 7: "SYSLOG_API_SEVERITY_DBG", + } + SyslogSeverity_value = map[string]uint32{ + "SYSLOG_API_SEVERITY_EMERG": 0, + "SYSLOG_API_SEVERITY_ALERT": 1, + "SYSLOG_API_SEVERITY_CRIT": 2, + "SYSLOG_API_SEVERITY_ERR": 3, + "SYSLOG_API_SEVERITY_WARN": 4, + "SYSLOG_API_SEVERITY_NOTICE": 5, + "SYSLOG_API_SEVERITY_INFO": 6, + "SYSLOG_API_SEVERITY_DBG": 7, + } +) + +func (x SyslogSeverity) String() string { + s, ok := SyslogSeverity_name[uint32(x)] + if ok { + return s + } + return "SyslogSeverity(" + strconv.Itoa(int(x)) + ")" +} + +// AddressWithPrefix defines alias 'address_with_prefix'. +type AddressWithPrefix Prefix + +func ParseAddressWithPrefix(s string) (AddressWithPrefix, error) { + prefix, err := ParsePrefix(s) + if err != nil { + return AddressWithPrefix{}, err + } + return AddressWithPrefix(prefix), nil +} +func (x AddressWithPrefix) String() string { + return Prefix(x).String() +} +func (x *AddressWithPrefix) MarshalText() ([]byte, error) { + return []byte(x.String()), nil +} +func (x *AddressWithPrefix) UnmarshalText(text []byte) error { + prefix, err := ParseAddressWithPrefix(string(text)) + if err != nil { + return err + } + *x = prefix + return nil +} + +// IP4Address defines alias 'ip4_address'. +type IP4Address [4]uint8 + +func ParseIP4Address(s string) (IP4Address, error) { + ip := net.ParseIP(s).To4() + if ip == nil { + return IP4Address{}, fmt.Errorf("invalid IP address: %s", s) + } + var ipaddr IP4Address + copy(ipaddr[:], ip.To4()) + return ipaddr, nil +} + +func (x IP4Address) ToIP() net.IP { + return net.IP(x[:]).To4() +} +func (x IP4Address) String() string { + return x.ToIP().String() +} +func (x *IP4Address) MarshalText() ([]byte, error) { + return []byte(x.String()), nil +} +func (x *IP4Address) UnmarshalText(text []byte) error { + ipaddr, err := ParseIP4Address(string(text)) + if err != nil { + return err + } + *x = ipaddr + return nil +} + +// IP4AddressWithPrefix defines alias 'ip4_address_with_prefix'. +type IP4AddressWithPrefix IP4Prefix + +// IP6Address defines alias 'ip6_address'. +type IP6Address [16]uint8 + +func ParseIP6Address(s string) (IP6Address, error) { + ip := net.ParseIP(s).To16() + if ip == nil { + return IP6Address{}, fmt.Errorf("invalid IP address: %s", s) + } + var ipaddr IP6Address + copy(ipaddr[:], ip.To16()) + return ipaddr, nil +} + +func (x IP6Address) ToIP() net.IP { + return net.IP(x[:]).To16() +} +func (x IP6Address) String() string { + return x.ToIP().String() +} +func (x *IP6Address) MarshalText() ([]byte, error) { + return []byte(x.String()), nil +} +func (x *IP6Address) UnmarshalText(text []byte) error { + ipaddr, err := ParseIP6Address(string(text)) + if err != nil { + return err + } + *x = ipaddr + return nil +} + +// IP6AddressWithPrefix defines alias 'ip6_address_with_prefix'. +type IP6AddressWithPrefix IP6Prefix + +// Address defines type 'address'. +type Address struct { + Af AddressFamily `binapi:"address_family,name=af" json:"af,omitempty"` + Un AddressUnion `binapi:"address_union,name=un" json:"un,omitempty"` +} + +func ParseAddress(s string) (Address, error) { + ip := net.ParseIP(s) + if ip == nil { + return Address{}, fmt.Errorf("invalid address: %s", s) + } + var addr Address + if ip.To4() == nil { + addr.Af = ADDRESS_IP6 + var ip6 IP6Address + copy(ip6[:], ip.To16()) + addr.Un.SetIP6(ip6) + } else { + addr.Af = ADDRESS_IP4 + var ip4 IP4Address + copy(ip4[:], ip.To4()) + addr.Un.SetIP4(ip4) + } + return addr, nil +} +func (x Address) ToIP() net.IP { + if x.Af == ADDRESS_IP6 { + ip6 := x.Un.GetIP6() + return net.IP(ip6[:]).To16() + } else { + ip4 := x.Un.GetIP4() + return net.IP(ip4[:]).To4() + } +} +func (x Address) String() string { + return x.ToIP().String() +} +func (x *Address) MarshalText() ([]byte, error) { + return []byte(x.String()), nil +} +func (x *Address) UnmarshalText(text []byte) error { + addr, err := ParseAddress(string(text)) + if err != nil { + return err + } + *x = addr + return nil +} + +// IP4Prefix defines type 'ip4_prefix'. +type IP4Prefix struct { + Address IP4Address `binapi:"ip4_address,name=address" json:"address,omitempty"` + Len uint8 `binapi:"u8,name=len" json:"len,omitempty"` +} + +func ParseIP4Prefix(s string) (prefix IP4Prefix, err error) { + hasPrefix := strings.Contains(s, "/") + if hasPrefix { + ip, network, err := net.ParseCIDR(s) + if err != nil { + return IP4Prefix{}, fmt.Errorf("invalid IP %s: %s", s, err) + } + maskSize, _ := network.Mask.Size() + prefix.Len = byte(maskSize) + prefix.Address, err = ParseIP4Address(ip.String()) + if err != nil { + return IP4Prefix{}, fmt.Errorf("invalid IP %s: %s", s, err) + } + } else { + ip := net.ParseIP(s) + defaultMaskSize, _ := net.CIDRMask(32, 32).Size() + if ip.To4() == nil { + defaultMaskSize, _ = net.CIDRMask(128, 128).Size() + } + prefix.Len = byte(defaultMaskSize) + prefix.Address, err = ParseIP4Address(ip.String()) + if err != nil { + return IP4Prefix{}, fmt.Errorf("invalid IP %s: %s", s, err) + } + } + return prefix, nil +} +func (x IP4Prefix) ToIPNet() *net.IPNet { + mask := net.CIDRMask(int(x.Len), 32) + ipnet := &net.IPNet{IP: x.Address.ToIP(), Mask: mask} + return ipnet +} +func (x IP4Prefix) String() string { + ip := x.Address.String() + return ip + "/" + strconv.Itoa(int(x.Len)) +} +func (x *IP4Prefix) MarshalText() ([]byte, error) { + return []byte(x.String()), nil +} +func (x *IP4Prefix) UnmarshalText(text []byte) error { + prefix, err := ParseIP4Prefix(string(text)) + if err != nil { + return err + } + *x = prefix + return nil +} + +// IP6Prefix defines type 'ip6_prefix'. +type IP6Prefix struct { + Address IP6Address `binapi:"ip6_address,name=address" json:"address,omitempty"` + Len uint8 `binapi:"u8,name=len" json:"len,omitempty"` +} + +func ParseIP6Prefix(s string) (prefix IP6Prefix, err error) { + hasPrefix := strings.Contains(s, "/") + if hasPrefix { + ip, network, err := net.ParseCIDR(s) + if err != nil { + return IP6Prefix{}, fmt.Errorf("invalid IP %s: %s", s, err) + } + maskSize, _ := network.Mask.Size() + prefix.Len = byte(maskSize) + prefix.Address, err = ParseIP6Address(ip.String()) + if err != nil { + return IP6Prefix{}, fmt.Errorf("invalid IP %s: %s", s, err) + } + } else { + ip := net.ParseIP(s) + defaultMaskSize, _ := net.CIDRMask(32, 32).Size() + if ip.To4() == nil { + defaultMaskSize, _ = net.CIDRMask(128, 128).Size() + } + prefix.Len = byte(defaultMaskSize) + prefix.Address, err = ParseIP6Address(ip.String()) + if err != nil { + return IP6Prefix{}, fmt.Errorf("invalid IP %s: %s", s, err) + } + } + return prefix, nil +} +func (x IP6Prefix) ToIPNet() *net.IPNet { + mask := net.CIDRMask(int(x.Len), 128) + ipnet := &net.IPNet{IP: x.Address.ToIP(), Mask: mask} + return ipnet +} +func (x IP6Prefix) String() string { + ip := x.Address.String() + return ip + "/" + strconv.Itoa(int(x.Len)) +} +func (x *IP6Prefix) MarshalText() ([]byte, error) { + return []byte(x.String()), nil +} +func (x *IP6Prefix) UnmarshalText(text []byte) error { + prefix, err := ParseIP6Prefix(string(text)) + if err != nil { + return err + } + *x = prefix + return nil +} + +// Mprefix defines type 'mprefix'. +type Mprefix struct { + Af AddressFamily `binapi:"address_family,name=af" json:"af,omitempty"` + GrpAddressLength uint16 `binapi:"u16,name=grp_address_length" json:"grp_address_length,omitempty"` + GrpAddress AddressUnion `binapi:"address_union,name=grp_address" json:"grp_address,omitempty"` + SrcAddress AddressUnion `binapi:"address_union,name=src_address" json:"src_address,omitempty"` +} + +// Prefix defines type 'prefix'. +type Prefix struct { + Address Address `binapi:"address,name=address" json:"address,omitempty"` + Len uint8 `binapi:"u8,name=len" json:"len,omitempty"` +} + +func ParsePrefix(ip string) (prefix Prefix, err error) { + hasPrefix := strings.Contains(ip, "/") + if hasPrefix { + netIP, network, err := net.ParseCIDR(ip) + if err != nil { + return Prefix{}, fmt.Errorf("invalid IP %s: %s", ip, err) + } + maskSize, _ := network.Mask.Size() + prefix.Len = byte(maskSize) + prefix.Address, err = ParseAddress(netIP.String()) + if err != nil { + return Prefix{}, fmt.Errorf("invalid IP %s: %s", ip, err) + } + } else { + netIP := net.ParseIP(ip) + defaultMaskSize, _ := net.CIDRMask(32, 32).Size() + if netIP.To4() == nil { + defaultMaskSize, _ = net.CIDRMask(128, 128).Size() + } + prefix.Len = byte(defaultMaskSize) + prefix.Address, err = ParseAddress(netIP.String()) + if err != nil { + return Prefix{}, fmt.Errorf("invalid IP %s: %s", ip, err) + } + } + return prefix, nil +} +func (x Prefix) ToIPNet() *net.IPNet { + var mask net.IPMask + if x.Address.Af == ADDRESS_IP4 { + mask = net.CIDRMask(int(x.Len), 32) + } else { + mask = net.CIDRMask(int(x.Len), 128) + } + ipnet := &net.IPNet{IP: x.Address.ToIP(), Mask: mask} + return ipnet +} +func (x Prefix) String() string { + ip := x.Address.String() + return ip + "/" + strconv.Itoa(int(x.Len)) +} +func (x *Prefix) MarshalText() ([]byte, error) { + return []byte(x.String()), nil +} +func (x *Prefix) UnmarshalText(text []byte) error { + prefix, err := ParsePrefix(string(text)) + if err != nil { + return err + } + *x = prefix + return nil +} + +// PrefixMatcher defines type 'prefix_matcher'. +type PrefixMatcher struct { + Le uint8 `binapi:"u8,name=le" json:"le,omitempty"` + Ge uint8 `binapi:"u8,name=ge" json:"ge,omitempty"` +} + +// AddressUnion defines union 'address_union'. +type AddressUnion struct { + // IP4 *IP4Address + // IP6 *IP6Address + XXX_UnionData [16]byte +} + +func AddressUnionIP4(a IP4Address) (u AddressUnion) { + u.SetIP4(a) + return +} +func (u *AddressUnion) SetIP4(a IP4Address) { + buf := codec.NewBuffer(u.XXX_UnionData[:]) + buf.EncodeBytes(a[:], 4) +} +func (u *AddressUnion) GetIP4() (a IP4Address) { + buf := codec.NewBuffer(u.XXX_UnionData[:]) + copy(a[:], buf.DecodeBytes(4)) + return +} + +func AddressUnionIP6(a IP6Address) (u AddressUnion) { + u.SetIP6(a) + return +} +func (u *AddressUnion) SetIP6(a IP6Address) { + buf := codec.NewBuffer(u.XXX_UnionData[:]) + buf.EncodeBytes(a[:], 16) +} +func (u *AddressUnion) GetIP6() (a IP6Address) { + buf := codec.NewBuffer(u.XXX_UnionData[:]) + copy(a[:], buf.DecodeBytes(16)) + return +} + +// SyslogGetFilter defines message 'syslog_get_filter'. +type SyslogGetFilter struct{} + +func (m *SyslogGetFilter) Reset() { *m = SyslogGetFilter{} } +func (*SyslogGetFilter) GetMessageName() string { return "syslog_get_filter" } +func (*SyslogGetFilter) GetCrcString() string { return "51077d14" } +func (*SyslogGetFilter) GetMessageType() api.MessageType { + return api.RequestMessage +} + +func (m *SyslogGetFilter) Size() (size int) { + if m == nil { + return 0 + } + return size +} +func (m *SyslogGetFilter) Marshal(b []byte) ([]byte, error) { + if b == nil { + b = make([]byte, m.Size()) + } + buf := codec.NewBuffer(b) + return buf.Bytes(), nil +} +func (m *SyslogGetFilter) Unmarshal(b []byte) error { + return nil +} + +// SyslogGetFilterReply defines message 'syslog_get_filter_reply'. +type SyslogGetFilterReply struct { + Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"` + Severity SyslogSeverity `binapi:"syslog_severity,name=severity" json:"severity,omitempty"` +} + +func (m *SyslogGetFilterReply) Reset() { *m = SyslogGetFilterReply{} } +func (*SyslogGetFilterReply) GetMessageName() string { return "syslog_get_filter_reply" } +func (*SyslogGetFilterReply) GetCrcString() string { return "eb1833f8" } +func (*SyslogGetFilterReply) GetMessageType() api.MessageType { + return api.ReplyMessage +} + +func (m *SyslogGetFilterReply) Size() (size int) { + if m == nil { + return 0 + } + size += 4 // m.Retval + size += 4 // m.Severity + return size +} +func (m *SyslogGetFilterReply) Marshal(b []byte) ([]byte, error) { + if b == nil { + b = make([]byte, m.Size()) + } + buf := codec.NewBuffer(b) + buf.EncodeInt32(m.Retval) + buf.EncodeUint32(uint32(m.Severity)) + return buf.Bytes(), nil +} +func (m *SyslogGetFilterReply) Unmarshal(b []byte) error { + buf := codec.NewBuffer(b) + m.Retval = buf.DecodeInt32() + m.Severity = SyslogSeverity(buf.DecodeUint32()) + return nil +} + +// SyslogGetSender defines message 'syslog_get_sender'. +type SyslogGetSender struct{} + +func (m *SyslogGetSender) Reset() { *m = SyslogGetSender{} } +func (*SyslogGetSender) GetMessageName() string { return "syslog_get_sender" } +func (*SyslogGetSender) GetCrcString() string { return "51077d14" } +func (*SyslogGetSender) GetMessageType() api.MessageType { + return api.RequestMessage +} + +func (m *SyslogGetSender) Size() (size int) { + if m == nil { + return 0 + } + return size +} +func (m *SyslogGetSender) Marshal(b []byte) ([]byte, error) { + if b == nil { + b = make([]byte, m.Size()) + } + buf := codec.NewBuffer(b) + return buf.Bytes(), nil +} +func (m *SyslogGetSender) Unmarshal(b []byte) error { + return nil +} + +// SyslogGetSenderReply defines message 'syslog_get_sender_reply'. +type SyslogGetSenderReply struct { + Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"` + SrcAddress IP4Address `binapi:"ip4_address,name=src_address" json:"src_address,omitempty"` + CollectorAddress IP4Address `binapi:"ip4_address,name=collector_address" json:"collector_address,omitempty"` + CollectorPort uint16 `binapi:"u16,name=collector_port" json:"collector_port,omitempty"` + VrfID uint32 `binapi:"u32,name=vrf_id" json:"vrf_id,omitempty"` + MaxMsgSize uint32 `binapi:"u32,name=max_msg_size" json:"max_msg_size,omitempty"` +} + +func (m *SyslogGetSenderReply) Reset() { *m = SyslogGetSenderReply{} } +func (*SyslogGetSenderReply) GetMessageName() string { return "syslog_get_sender_reply" } +func (*SyslogGetSenderReply) GetCrcString() string { return "d3da60ac" } +func (*SyslogGetSenderReply) GetMessageType() api.MessageType { + return api.ReplyMessage +} + +func (m *SyslogGetSenderReply) Size() (size int) { + if m == nil { + return 0 + } + size += 4 // m.Retval + size += 1 * 4 // m.SrcAddress + size += 1 * 4 // m.CollectorAddress + size += 2 // m.CollectorPort + size += 4 // m.VrfID + size += 4 // m.MaxMsgSize + return size +} +func (m *SyslogGetSenderReply) Marshal(b []byte) ([]byte, error) { + if b == nil { + b = make([]byte, m.Size()) + } + buf := codec.NewBuffer(b) + buf.EncodeInt32(m.Retval) + buf.EncodeBytes(m.SrcAddress[:], 4) + buf.EncodeBytes(m.CollectorAddress[:], 4) + buf.EncodeUint16(m.CollectorPort) + buf.EncodeUint32(m.VrfID) + buf.EncodeUint32(m.MaxMsgSize) + return buf.Bytes(), nil +} +func (m *SyslogGetSenderReply) Unmarshal(b []byte) error { + buf := codec.NewBuffer(b) + m.Retval = buf.DecodeInt32() + copy(m.SrcAddress[:], buf.DecodeBytes(4)) + copy(m.CollectorAddress[:], buf.DecodeBytes(4)) + m.CollectorPort = buf.DecodeUint16() + m.VrfID = buf.DecodeUint32() + m.MaxMsgSize = buf.DecodeUint32() + return nil +} + +// SyslogSetFilter defines message 'syslog_set_filter'. +type SyslogSetFilter struct { + Severity SyslogSeverity `binapi:"syslog_severity,name=severity" json:"severity,omitempty"` +} + +func (m *SyslogSetFilter) Reset() { *m = SyslogSetFilter{} } +func (*SyslogSetFilter) GetMessageName() string { return "syslog_set_filter" } +func (*SyslogSetFilter) GetCrcString() string { return "571348c3" } +func (*SyslogSetFilter) GetMessageType() api.MessageType { + return api.RequestMessage +} + +func (m *SyslogSetFilter) Size() (size int) { + if m == nil { + return 0 + } + size += 4 // m.Severity + return size +} +func (m *SyslogSetFilter) Marshal(b []byte) ([]byte, error) { + if b == nil { + b = make([]byte, m.Size()) + } + buf := codec.NewBuffer(b) + buf.EncodeUint32(uint32(m.Severity)) + return buf.Bytes(), nil +} +func (m *SyslogSetFilter) Unmarshal(b []byte) error { + buf := codec.NewBuffer(b) + m.Severity = SyslogSeverity(buf.DecodeUint32()) + return nil +} + +// SyslogSetFilterReply defines message 'syslog_set_filter_reply'. +type SyslogSetFilterReply struct { + Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"` +} + +func (m *SyslogSetFilterReply) Reset() { *m = SyslogSetFilterReply{} } +func (*SyslogSetFilterReply) GetMessageName() string { return "syslog_set_filter_reply" } +func (*SyslogSetFilterReply) GetCrcString() string { return "e8d4e804" } +func (*SyslogSetFilterReply) GetMessageType() api.MessageType { + return api.ReplyMessage +} + +func (m *SyslogSetFilterReply) Size() (size int) { + if m == nil { + return 0 + } + size += 4 // m.Retval + return size +} +func (m *SyslogSetFilterReply) Marshal(b []byte) ([]byte, error) { + if b == nil { + b = make([]byte, m.Size()) + } + buf := codec.NewBuffer(b) + buf.EncodeInt32(m.Retval) + return buf.Bytes(), nil +} +func (m *SyslogSetFilterReply) Unmarshal(b []byte) error { + buf := codec.NewBuffer(b) + m.Retval = buf.DecodeInt32() + return nil +} + +// SyslogSetSender defines message 'syslog_set_sender'. +type SyslogSetSender struct { + SrcAddress IP4Address `binapi:"ip4_address,name=src_address" json:"src_address,omitempty"` + CollectorAddress IP4Address `binapi:"ip4_address,name=collector_address" json:"collector_address,omitempty"` + CollectorPort uint16 `binapi:"u16,name=collector_port" json:"collector_port,omitempty"` + VrfID uint32 `binapi:"u32,name=vrf_id" json:"vrf_id,omitempty"` + MaxMsgSize uint32 `binapi:"u32,name=max_msg_size" json:"max_msg_size,omitempty"` +} + +func (m *SyslogSetSender) Reset() { *m = SyslogSetSender{} } +func (*SyslogSetSender) GetMessageName() string { return "syslog_set_sender" } +func (*SyslogSetSender) GetCrcString() string { return "bb641285" } +func (*SyslogSetSender) GetMessageType() api.MessageType { + return api.RequestMessage +} + +func (m *SyslogSetSender) Size() (size int) { + if m == nil { + return 0 + } + size += 1 * 4 // m.SrcAddress + size += 1 * 4 // m.CollectorAddress + size += 2 // m.CollectorPort + size += 4 // m.VrfID + size += 4 // m.MaxMsgSize + return size +} +func (m *SyslogSetSender) Marshal(b []byte) ([]byte, error) { + if b == nil { + b = make([]byte, m.Size()) + } + buf := codec.NewBuffer(b) + buf.EncodeBytes(m.SrcAddress[:], 4) + buf.EncodeBytes(m.CollectorAddress[:], 4) + buf.EncodeUint16(m.CollectorPort) + buf.EncodeUint32(m.VrfID) + buf.EncodeUint32(m.MaxMsgSize) + return buf.Bytes(), nil +} +func (m *SyslogSetSender) Unmarshal(b []byte) error { + buf := codec.NewBuffer(b) + copy(m.SrcAddress[:], buf.DecodeBytes(4)) + copy(m.CollectorAddress[:], buf.DecodeBytes(4)) + m.CollectorPort = buf.DecodeUint16() + m.VrfID = buf.DecodeUint32() + m.MaxMsgSize = buf.DecodeUint32() + return nil +} + +// SyslogSetSenderReply defines message 'syslog_set_sender_reply'. +type SyslogSetSenderReply struct { + Retval int32 `binapi:"i32,name=retval" json:"retval,omitempty"` +} + +func (m *SyslogSetSenderReply) Reset() { *m = SyslogSetSenderReply{} } +func (*SyslogSetSenderReply) GetMessageName() string { return "syslog_set_sender_reply" } +func (*SyslogSetSenderReply) GetCrcString() string { return "e8d4e804" } +func (*SyslogSetSenderReply) GetMessageType() api.MessageType { + return api.ReplyMessage +} + +func (m *SyslogSetSenderReply) Size() (size int) { + if m == nil { + return 0 + } + size += 4 // m.Retval + return size +} +func (m *SyslogSetSenderReply) Marshal(b []byte) ([]byte, error) { + if b == nil { + b = make([]byte, m.Size()) + } + buf := codec.NewBuffer(b) + buf.EncodeInt32(m.Retval) + return buf.Bytes(), nil +} +func (m *SyslogSetSenderReply) Unmarshal(b []byte) error { + buf := codec.NewBuffer(b) + m.Retval = buf.DecodeInt32() + return nil +} + +func init() { file_syslog_binapi_init() } +func file_syslog_binapi_init() { + api.RegisterMessage((*SyslogGetFilter)(nil), "syslog_get_filter_51077d14") + api.RegisterMessage((*SyslogGetFilterReply)(nil), "syslog_get_filter_reply_eb1833f8") + api.RegisterMessage((*SyslogGetSender)(nil), "syslog_get_sender_51077d14") + api.RegisterMessage((*SyslogGetSenderReply)(nil), "syslog_get_sender_reply_d3da60ac") + api.RegisterMessage((*SyslogSetFilter)(nil), "syslog_set_filter_571348c3") + api.RegisterMessage((*SyslogSetFilterReply)(nil), "syslog_set_filter_reply_e8d4e804") + api.RegisterMessage((*SyslogSetSender)(nil), "syslog_set_sender_bb641285") + api.RegisterMessage((*SyslogSetSenderReply)(nil), "syslog_set_sender_reply_e8d4e804") +} + +// Messages returns list of all messages in this module. +func AllMessages() []api.Message { + return []api.Message{ + (*SyslogGetFilter)(nil), + (*SyslogGetFilterReply)(nil), + (*SyslogGetSender)(nil), + (*SyslogGetSenderReply)(nil), + (*SyslogSetFilter)(nil), + (*SyslogSetFilterReply)(nil), + (*SyslogSetSender)(nil), + (*SyslogSetSenderReply)(nil), + } +} diff --git a/internal/testbinapi/binapi2001/syslog/syslog_rpc.ba.go b/internal/testbinapi/binapi2001/syslog/syslog_rpc.ba.go new file mode 100644 index 0000000..a1f4a27 --- /dev/null +++ b/internal/testbinapi/binapi2001/syslog/syslog_rpc.ba.go @@ -0,0 +1,60 @@ +// Code generated by GoVPP's binapi-generator. DO NOT EDIT. + +package syslog + +import ( + "context" + api "git.fd.io/govpp.git/api" +) + +// RPCService defines RPC service syslog. +type RPCService interface { + SyslogGetFilter(ctx context.Context, in *SyslogGetFilter) (*SyslogGetFilterReply, error) + SyslogGetSender(ctx context.Context, in *SyslogGetSender) (*SyslogGetSenderReply, error) + SyslogSetFilter(ctx context.Context, in *SyslogSetFilter) (*SyslogSetFilterReply, error) + SyslogSetSender(ctx context.Context, in *SyslogSetSender) (*SyslogSetSenderReply, error) +} + +type serviceClient struct { + conn api.Connection +} + +func NewServiceClient(conn api.Connection) RPCService { + return &serviceClient{conn} +} + +func (c *serviceClient) SyslogGetFilter(ctx context.Context, in *SyslogGetFilter) (*SyslogGetFilterReply, error) { + out := new(SyslogGetFilterReply) + err := c.conn.Invoke(ctx, in, out) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *serviceClient) SyslogGetSender(ctx context.Context, in *SyslogGetSender) (*SyslogGetSenderReply, error) { + out := new(SyslogGetSenderReply) + err := c.conn.Invoke(ctx, in, out) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *serviceClient) SyslogSetFilter(ctx context.Context, in *SyslogSetFilter) (*SyslogSetFilterReply, error) { + out := new(SyslogSetFilterReply) + err := c.conn.Invoke(ctx, in, out) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *serviceClient) SyslogSetSender(ctx context.Context, in *SyslogSetSender) (*SyslogSetSenderReply, error) { + out := new(SyslogSetSenderReply) + err := c.conn.Invoke(ctx, in, out) + if err != nil { + return nil, err + } + return out, nil +} -- cgit 1.2.3-korg