Documentation ¶
Overview ¶
Package lwotg implements a lightweight, extensible OpenTrafficGenerator (github.com/open-traffic-generator) implementation. OpenTrafficGenerator is often abbreviated to OTG.
Index ¶
- Constants
- type FlowController
- type FlowGeneratorFn
- type Hint
- type OTGIntf
- type Server
- func (s *Server) AddConfigHandler(fn func(*otg.Config) error)
- func (s *Server) AddFlowHandlers(fns ...FlowGeneratorFn)
- func (s *Server) GetConfig(_ context.Context, _ *emptypb.Empty) (*otg.GetConfigResponse, error)
- func (s *Server) SetConfig(ctx context.Context, req *otg.SetConfigRequest) (*otg.SetConfigResponse, error)
- func (s *Server) SetControlState(ctx context.Context, req *otg.SetControlStateRequest) (*otg.SetControlStateResponse, error)
- func (s *Server) SetHintChannel(ch chan Hint)
- func (s *Server) SetProtocolHandler(fn func(*otg.Config, otg.StateProtocolAll_State_Enum) error)
- type TXRXFn
- type TXRXWrapper
Constants ¶
const ( // InterfaceHintGroupName is the name of the group that is used to // handle interface details. InterfaceHintGroupName string = "interface_map" )
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type FlowController ¶
type FlowController struct { // ID is a unique ID for the controller that allows tracing through the system. ID string // Stop is a channel used to indicate that the function that has been called should // cease to send or receive packets. Stop chan struct{} }
FlowController acts as the control mechanism for a specific direction of a specific flow.
func NewFlowController ¶
func NewFlowController(id string) *FlowController
NewFlowController returns an initialised FlowController.
type FlowGeneratorFn ¶
FlowGeneratorFn is a function that takes an input OTG Flow and, if it is able to, returns a TXRXFn that controls that flow. If the function is not able to handle the flow (e.g., it is an IP flow and the function can handle only MPLS) it returns no TXRXFn, and sets the bool return argument to false. If the function can handle the flow, it returns a TXRXFn that can be used to start the flow, with the bool return argument set to true. Errors encountered whilst generating a TXRXFn for a flow that the function can return should be returned and are treated as errors that should be returned to the caller.
The arguments to a FlowGeneratorFn are as follows:
- otg.Flow - the flow that is to be generated as described by the OTG schema.
- []*OTGIntf - information as to the set of interfaces that are currently within the OTG configuration. This information can be used to map the flow creation functionality to the underlying interface.
type Hint ¶
type Hint struct { // Group is a string used to specify a name for a set of hints that // are associated with one another. Group string // Key is the name of the hint. Key string // Value is the value stored for the hint. Value string }
Hint is <group, key, value> tuple that can be handed to modules of the OTG implementation to perform their functions. For example, it may be used to communicate mappings between system interfaces and the names that are used in OTG for them.
type OTGIntf ¶
type OTGIntf struct { // OTGEthernetName specifies the name of the interface in the OTG configuration when referred to // as an Ethernet port. OTGEthernetName string // OTGPortName specifies the name of the interface in the overall OTG configuration. OTGPortName string // SystemName specifies the name of the interface on the system. SystemName string // IPv4 specifies the IPv4 addresses associated with the interface. IPv4 []*ipAddress }
OTGIntf describes an interface in the OTG configuration.
type Server ¶
type Server struct { *otg.UnimplementedOpenapiServer // contains filtered or unexported fields }
Server implements the OTG ("Openapi") server.
func (*Server) AddConfigHandler ¶
AddConfigHandler adds the specified fn to the set of config handlers.
func (*Server) AddFlowHandlers ¶
func (s *Server) AddFlowHandlers(fns ...FlowGeneratorFn)
AddFlowHandlers adds the set of flow generator functions specified to the flow handlers that are considered as candidates by the server.
func (*Server) GetConfig ¶
GetConfig retrieves the current OTG configuration from the lwotg instance, implementing the GetConfig RPC.
func (*Server) SetConfig ¶
func (s *Server) SetConfig(ctx context.Context, req *otg.SetConfigRequest) (*otg.SetConfigResponse, error)
SetConfig handles the SetConfig OTG RPC. In this implementation it calls the set of configHandlers that have been registered with the server.
func (*Server) SetControlState ¶
func (s *Server) SetControlState(ctx context.Context, req *otg.SetControlStateRequest) (*otg.SetControlStateResponse, error)
SetControlState handles the SetControlState OTG RPC. This implementation only supports:
- starting and stopping all protocols, by calling the protocolHandler function that has been specified.
- starting and stopping all traffic, by calling startTraffic and stopTraffic.
It returns an error if an unsupported option is requested.
func (*Server) SetHintChannel ¶
SetHintChannel sets the hint channel to the specified channel.
func (*Server) SetProtocolHandler ¶
SetProtocolHandler sets the specified function as the function to be called when the SetControlState RPC is called with protocol related options.
type TXRXFn ¶
type TXRXFn func(tx, rx *FlowController)
TXRXFn is a function that handles the send and receive of packets for a particular flow. When called it should begin tranmitting packets using the tx FlowController channels, and receiving them using the rx FlowController. Tx and Rx should be spawned into new goroutines and the function should return. Telemetry that is published by the flow should be written to the corresponding FlowController GNMI channel. Encountered errors should be written to the error channel.