Source code for xoa_driver.internals.commands.pe_commands

from __future__ import annotations
from dataclasses import dataclass
import typing
import functools

from xoa_driver.internals.core.builders import (
    build_get_request,
    build_set_request
)
from xoa_driver.internals.core import interfaces
from xoa_driver.internals.core.token import Token
from xoa_driver.internals.core.transporter.registry import register_command
from xoa_driver.internals.core.transporter.protocol.payload import (
    field,
    RequestBodyStruct,
    ResponseBodyStruct,
    XmpByte,
    XmpInt,
    XmpLong,
    XmpStr
)
from .enums import (
    OnOff,
    TPLDMode,
    CorruptionType,
    PolicerMode,
)


[docs] @register_command @dataclass class PE_FCSDROP: """ The action on packets with FCS errors on a port. """ code: typing.ClassVar[int] = 1601 pushed: typing.ClassVar[bool] = True _connection: 'interfaces.IConnection' _module: int _port: int class GetDataAttr(ResponseBodyStruct): on_off: OnOff = field(XmpByte()) """coded byte, the action on packets with FCS errors on a port""" class SetDataAttr(RequestBodyStruct): on_off: OnOff = field(XmpByte()) """coded byte, the action on packets with FCS errors on a port"""
[docs] def get(self) -> Token[GetDataAttr]: """Get the status of whether the action on packets with FCS errors on a port is enabled. :return: whether the action on packets with FCS errors on a port is enabled :rtype: PE_FCSDROP.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port))
[docs] def set(self, on_off: OnOff) -> Token[None]: """Set the status of whether the action on packets with FCS errors on a port is enabled. :param on_off: whether the action on packets with FCS errors on a port is enabled :type on_off: OnOff """ return Token(self._connection, build_set_request(self, module=self._module, port=self._port, on_off=on_off))
set_off = functools.partialmethod(set, OnOff.OFF) """Disable the action on packets with FCS errors on a port. """ set_on = functools.partialmethod(set, OnOff.ON) """Enable the action on packets with FCS errors on a port. """
[docs] @register_command @dataclass class PE_TPLDMODE: """ The action indicates the TPLD mode to be used per port. """ code: typing.ClassVar[int] = 1602 pushed: typing.ClassVar[bool] = True _connection: 'interfaces.IConnection' _module: int _port: int class GetDataAttr(ResponseBodyStruct): mode: TPLDMode = field(XmpByte()) """coded byte, indicating the TPLD mode.""" class SetDataAttr(RequestBodyStruct): mode: TPLDMode = field(XmpByte()) """coded byte, indicating the TPLD mode."""
[docs] def get(self) -> Token[GetDataAttr]: """Get the TPLD mode of the port. :return: indicating the TPLD mode :rtype: PE_TPLDMODE.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port))
[docs] def set(self, mode: TPLDMode) -> Token[None]: """Set the TPLD mode of the port. :param mode: indicating the TPLD mode :type mode: TPLDMode """ return Token(self._connection, build_set_request(self, module=self._module, port=self._port, mode=mode))
set_normal = functools.partialmethod(set, TPLDMode.NORMAL) """Set the TPLD mode to Normal. """ set_micro = functools.partialmethod(set, TPLDMode.MICRO) """Set the TPLD mode to Micro. """
[docs] @register_command @dataclass class PE_COMMENT: """ Flow description. """ code: typing.ClassVar[int] = 1605 pushed: typing.ClassVar[bool] = True _connection: 'interfaces.IConnection' _module: int _port: int _flow_xindex: int class GetDataAttr(ResponseBodyStruct): comment: str = field(XmpStr()) """string, containing the description of the flow.""" class SetDataAttr(RequestBodyStruct): comment: str = field(XmpStr()) """string, containing the description of the flow."""
[docs] def get(self) -> Token[GetDataAttr]: """Get the flow description. :return: the description of the flow :rtype: PE_COMMENT.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port, indices=[self._flow_xindex]))
[docs] def set(self, comment: str) -> Token[None]: """Set the flow description. :param comment: the description of the flow :type comment: str """ return Token(self._connection, build_set_request(self, module=self._module, port=self._port, indices=[self._flow_xindex], comment=comment))
[docs] @register_command @dataclass class PE_INDICES: """ Get the flow indices. Currently the number of flows is 8. """ code: typing.ClassVar[int] = 1608 pushed: typing.ClassVar[bool] = True _connection: 'interfaces.IConnection' _module: int _port: int class GetDataAttr(ResponseBodyStruct): flow0_id: int = field(XmpInt()) """integer, id of flow 0.""" flow1_id: int = field(XmpInt()) """integer, id of flow 1.""" flow2_id: int = field(XmpInt()) """integer, id of flow 2.""" flow3_id: int = field(XmpInt()) """integer, id of flow 3.""" flow4_id: int = field(XmpInt()) """integer, id of flow 4.""" flow5_id: int = field(XmpInt()) """integer, id of flow 5.""" flow6_id: int = field(XmpInt()) """integer, id of flow 6.""" flow7_id: int = field(XmpInt()) """integer, id of flow 7."""
[docs] def get(self) -> Token[GetDataAttr]: """Get the flow indices of a port. Currently the number of flows is fixed to 8. :return: the flow indices of a port :rtype: PE_INDICES.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port))
[docs] @register_command @dataclass class PE_LATENCYRANGE: """ Retrieve minimum and maximum configurable latency per flow in nanoseconds. """ code: typing.ClassVar[int] = 1646 pushed: typing.ClassVar[bool] = False _connection: 'interfaces.IConnection' _module: int _port: int _flow_xindex: int class GetDataAttr(ResponseBodyStruct): min: int = field(XmpLong()) """long integer, minimum configurable latency per flow in nanoseconds.""" max: int = field(XmpLong()) """long integer, maximum configurable latency per flow in nanoseconds."""
[docs] def get(self) -> Token[GetDataAttr]: """Get the minimum and maximum configurable latency per flow in nanoseconds. :return: minimum and maximum configurable latency per flow in nanoseconds. :rtype: PE_LATENCYRANGE.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port, indices=[self._flow_xindex]))
[docs] @register_command @dataclass class PE_CORRUPT: """ Configures impairment corruption type. .. note:: IP / TCP / UDP corruption modes are not supported on default flow (0) """ code: typing.ClassVar[int] = 1660 pushed: typing.ClassVar[bool] = True _connection: 'interfaces.IConnection' _module: int _port: int _flow_xindex: int class GetDataAttr(ResponseBodyStruct): corruption_type: CorruptionType = field(XmpByte()) """coded byte, specifying corruption type.""" class SetDataAttr(RequestBodyStruct): corruption_type: CorruptionType = field(XmpByte()) """coded byte, specifying corruption type."""
[docs] def get(self) -> Token[GetDataAttr]: """Get the impairment corruption type of a flow. :return: the impairment corruption type of a flow. :rtype: PE_CORRUPT.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port, indices=[self._flow_xindex]))
[docs] def set(self, corruption_type: CorruptionType) -> Token[None]: """Set the impairment corruption type. :param corruption_type: corruption type :type corruption_type: CorruptionType """ return Token(self._connection, build_set_request(self, module=self._module, port=self._port, indices=[self._flow_xindex], corruption_type=corruption_type))
set_off = functools.partialmethod(set, CorruptionType.OFF) """Set the corruption type to OFF. """ set_eth = functools.partialmethod(set, CorruptionType.ETH) """Set the corruption type to Ethernet. """ set_ip = functools.partialmethod(set, CorruptionType.IP) """Set the corruption type to IP. """ set_udp = functools.partialmethod(set, CorruptionType.UDP) """Set the corruption type to UDP. """ set_tcp = functools.partialmethod(set, CorruptionType.TCP) """Set the corruption type to TCP. """ set_ber = functools.partialmethod(set, CorruptionType.BER) """Set the corruption type to Bit Error Rate. """
[docs] @register_command @dataclass class PE_MISORDER: """ Configures the misordering depth in number of packets. .. note:: probability * (depth + 1) should be less than 1,000,000. (see PED_FIXED) """ code: typing.ClassVar[int] = 1661 pushed: typing.ClassVar[bool] = True _connection: 'interfaces.IConnection' _module: int _port: int _flow_xindex: int class GetDataAttr(ResponseBodyStruct): depth: int = field(XmpInt()) """integer, specifies the misordering depth (Range 1 - 32). Default value. probability * (depth + 1) should be less than 1,000,000. (see PED_FIXED)""" class SetDataAttr(RequestBodyStruct): depth: int = field(XmpInt()) """integer, specifies the misordering depth (Range 1 - 32). Default value. probability * (depth + 1) should be less than 1,000,000. (see PED_FIXED)"""
[docs] def get(self) -> Token[GetDataAttr]: """Get the misordering depth in number of packets of a flow. :return: the misordering depth (Range 1 - 32). Default value. :rtype: PE_MISORDER.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port, indices=[self._flow_xindex]))
[docs] def set(self, depth: int) -> Token[None]: """Set the misordering depth in number of packets of a flow. Note: probability [see PED_FIXED] * (depth + 1) should be less than 1,000,000. :param depth: the misordering depth (Range 1 - 32). Default value. :type depth: int """ return Token(self._connection, build_set_request(self, module=self._module, port=self._port, indices=[self._flow_xindex], depth=depth))
[docs] @register_command @dataclass class PE_BANDPOLICER: """ Configures the bandwidth policer. """ code: typing.ClassVar[int] = 1662 pushed: typing.ClassVar[bool] = True _connection: 'interfaces.IConnection' _module: int _port: int _flow_xindex: int class GetDataAttr(ResponseBodyStruct): on_off: OnOff = field(XmpByte()) """coded byte, enables/disables policer. Note: PED_ENABLE is not supported for the policer.""" mode: PolicerMode = field(XmpByte()) """coded byte, sets policer mode.""" cir: int = field(XmpInt()) """integer, policer committed information rate in units of 100 kbps (range 0 to 1000000), default is 0.""" cbs: int = field(XmpInt()) """integer, policer committed burst burst in bytes (range 0 to 4194304), default is 0.""" class SetDataAttr(RequestBodyStruct): on_off: OnOff = field(XmpByte()) """coded byte, enables/disables policer. Note: PED_ENABLE is not supported for the policer.""" mode: PolicerMode = field(XmpByte()) """coded byte, sets policer mode.""" cir: int = field(XmpInt()) """integer, policer committed information rate in units of 100 kbps (range 0 to 1000000), default is 0.""" cbs: int = field(XmpInt()) """integer, policer committed burst size in bytes (range 0 to 4194304), default is 0."""
[docs] def get(self) -> Token[GetDataAttr]: """Get the bandwidth policer configuration. :return: enabled/disabled, policer mode, committed information rate, and committed burst size. :rtype: PE_BANDPOLICER.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port, indices=[self._flow_xindex]))
[docs] def set(self, on_off: OnOff, mode: PolicerMode, cir: int, cbs: int) -> Token[None]: """Set the bandwidth policer configuration. :param on_off: enables/disables policer. Note: PED_ENABLE is not supported for the policer. :type on_off: OnOff :param mode: policer mode :type mode: PolicerMode :param cir: policer committed information rate in units of 100 kbps (range 0 to 1000000), default is 0. :type cir: int :param cbs: policer committed burst burst in bytes (range 0 to 4194304), default is 0. :type cbs: int """ return Token(self._connection, build_set_request(self, module=self._module, port=self._port, indices=[self._flow_xindex], on_off=on_off, mode=mode, cir=cir, cbs=cbs))
[docs] @register_command @dataclass class PE_BANDSHAPER: """ Configures the bandwidth shaper. L1 (0) (Shaper performed at Layer 1 level. I.e. including the preamble and min interpacket gap) L2 (1) (Shaper performed at Layer 2 level. I.e. excluding the preamble and min interpacket gap) Default value: L2 (0) """ code: typing.ClassVar[int] = 1663 pushed: typing.ClassVar[bool] = True _connection: 'interfaces.IConnection' _module: int _port: int _flow_xindex: int class GetDataAttr(ResponseBodyStruct): on_off: OnOff = field(XmpByte()) """coded byte, enables/disables shaper.""" mode: PolicerMode = field(XmpByte()) """coded byte, sets shaper mode.""" cir: int = field(XmpInt()) """integer, shaper committed information rate in units of 100 kbps (range 0 to 1000000), default is 0.""" cbs: int = field(XmpInt()) """integer, shaper committed burst size in bytes (range 0 to 4194304), default is 0.""" buffer_size: int = field(XmpInt()) """integer, shaper buffer size in bytes (range 0 to 2097152), default is 0.""" class SetDataAttr(RequestBodyStruct): on_off: OnOff = field(XmpByte()) """coded byte, enables/disables shaper.""" mode: PolicerMode = field(XmpByte()) """coded byte, sets shaper mode.""" cir: int = field(XmpInt()) """integer, shaper committed information rate in units of 100 kbps (range 0 to 1000000), default is 0.""" cbs: int = field(XmpInt()) """integer, shaper committed burst size in bytes (range 0 to 4194304), default is 0.""" buffer_size: int = field(XmpInt()) """integer, shaper buffer size in bytes (range 0 to 2097152), default is 0."""
[docs] def get(self) -> Token[GetDataAttr]: """Get the bandwidth shaper configuration. :return: the bandwidth shaper configuration, including on/off, mode, CIR, CBS, and shaper buffer size. :rtype: PE_BANDSHAPER.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port, indices=[self._flow_xindex]))
[docs] def set(self, on_off: OnOff, mode: PolicerMode, cir: int, cbs: int, buffer_size: int) -> Token[None]: """Set the bandwidth shaper configuration. :param on_off: enables/disables shaper :type on_off: OnOff :param mode: shaper mode :type mode: PolicerMode :param cir: shaper committed information rate in units of 100 kbps (range 0 to 1000000), default is 0. :type cir: int :param cbs: shaper committed burst size in bytes (range 0 to 4194304), default is 0. :type cbs: int :param buffer_size: shaper buffer size in bytes (range 0 to 2097152), default is 0. :type buffer_size: int """ return Token( self._connection, build_set_request( self, module=self._module, port=self._port, indices=[self._flow_xindex], on_off=on_off, mode=mode, cir=cir, cbs=cbs, buffer_size=buffer_size ) )
[docs] @register_command @dataclass class PE_DROPTOTAL: """ Obtains statistics concerning all the packets dropped between this receive port and its partner TX port. """ code: typing.ClassVar[int] = 1750 pushed: typing.ClassVar[bool] = False _connection: 'interfaces.IConnection' _module: int _port: int class GetDataAttr(ResponseBodyStruct): pkt_drop_count_total: int = field(XmpLong()) """long integer, total number of packets dropped in all flows.""" pkt_drop_count_programmed: int = field(XmpLong()) """long integer, total number of packets dropped as programmed in all flows.""" pkt_drop_count_bandwidth: int = field(XmpLong()) """long integer, total number of packets dropped due to bandwidth control in all flows.""" pkt_drop_count_other: int = field(XmpLong()) """long integer, total number of packets dropped for other reasons in all flows.""" pkt_drop_ratio_total: int = field(XmpLong()) """long integer, ratio of number of packets dropped in all flows, expressed in ppm.""" pkt_drop_ratio_programmed: int = field(XmpLong()) """long integer, ratio of number of packets dropped as programmed in all flows, expressed in ppm.""" pkt_drop_ratio_bandwidth: int = field(XmpLong()) """long integer, ratio of number of packets dropped due to bandwidth control in all flows, expressed in ppm.""" pkt_drop_ratio_other: int = field(XmpLong()) """long integer, ratio of number of packets dropped for other reasons in all flows, expressed in ppm."""
[docs] def get(self) -> Token[GetDataAttr]: """Get statistics concerning all the packets dropped between this receive port and its partner TX port. :return: total number of packets dropped in all flows, total number of packets dropped as programmed in all flows, total number of packets dropped due to bandwidth control in all flows, total number of packets dropped for other reasons in all flows, ratio of number of packets dropped in all flows, expressed in ppm, ratio of number of packets dropped as programmed in all flows, expressed in ppm, ratio of number of packets dropped due to bandwidth control in all flows, expressed in ppm, ratio of number of packets dropped for other reasons in all flows, expressed in ppm. :rtype: PE_DROPTOTAL.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port))
[docs] @register_command @dataclass class PE_LATENCYTOTAL: """ Obtains statistics concerning all the packets delayed this receive port and its partner TX port. """ code: typing.ClassVar[int] = 1751 pushed: typing.ClassVar[bool] = False _connection: 'interfaces.IConnection' _module: int _port: int class GetDataAttr(ResponseBodyStruct): pkt_count: int = field(XmpLong()) """long integer, number of packets delayed in all flows.""" ratio: int = field(XmpLong()) """long integer, ratio of number of packets delayed in all flows, expressed in ppm."""
[docs] def get(self) -> Token[GetDataAttr]: """Get statistics concerning all the packets delayed this receive port and its partner TX port. :return: number of packets delayed in all flows, and ratio of number of packets delayed in all flows, expressed in ppm. :rtype: PE_LATENCYTOTAL.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port))
[docs] @register_command @dataclass class PE_DUPTOTAL: """ Obtains statistics concerning all the packets duplicated between this receive port and its partner TX port. """ code: typing.ClassVar[int] = 1752 pushed: typing.ClassVar[bool] = False _connection: 'interfaces.IConnection' _module: int _port: int class GetDataAttr(ResponseBodyStruct): pkt_count: int = field(XmpLong()) """long integer, number of packets duplicated in all flows.""" ratio: int = field(XmpLong()) """long integer, ratio of number of packets duplicated in all flows, expressed in ppm."""
[docs] def get(self) -> Token[GetDataAttr]: """Get statistics concerning all the packets duplicated between this receive port and its partner TX port. :return: number of packets duplicated in all flows, ratio of number of packets duplicated in all flows, expressed in ppm. :rtype: PE_DUPTOTAL.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port))
[docs] @register_command @dataclass class PE_MISTOTAL: """ Obtains statistics concerning all the packets mis-ordered between this receive port and its partner TX port. """ code: typing.ClassVar[int] = 1753 pushed: typing.ClassVar[bool] = False _connection: 'interfaces.IConnection' _module: int _port: int class GetDataAttr(ResponseBodyStruct): pkt_count: int = field(XmpLong()) """long integer, number of packets mis-ordered in all flows.""" ratio: int = field(XmpLong()) """long integer, number of packets mis-ordered in all flows, expressed in ppm."""
[docs] def get(self) -> Token[GetDataAttr]: """Get statistics concerning all the packets mis-ordered between this receive port and its partner TX port. :return: number of packets mis-ordered in all flows, number of packets mis-ordered in all flows, expressed in ppm. :rtype: PE_MISTOTAL.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port))
[docs] @register_command @dataclass class PE_CORTOTAL: """ Obtains statistics concerning all the packets corrupted on between this receive port and its partner TX port. """ code: typing.ClassVar[int] = 1754 pushed: typing.ClassVar[bool] = False _connection: 'interfaces.IConnection' _module: int _port: int class GetDataAttr(ResponseBodyStruct): total_corrupted_pkt_count: int = field(XmpLong()) """long integer, number of packets corrupted in all flows.""" fcs_corrupted_pkt_count: int = field(XmpLong()) """long integer, number of packets with Ethernet FCS corrupted in all flows.""" ip_corrupted_pkt_count: int = field(XmpLong()) """long integer, number of packets with IP header checksum corrupted in all flows.""" udp_corrupted_pkt_count: int = field(XmpLong()) """long integer, number of packets with UDP checksum corrupted in all flows.""" tcp_corrupted_pkt_count: int = field(XmpLong()) """long integer, number of packets with TCP checksum corrupted in all flows.""" total_corrupted_pkt_ratio: int = field(XmpLong()) """long integer, ratio of number of packets corrupted in all flows, expressed in ppm.""" fcs_corrupted_pkt_ratio: int = field(XmpLong()) """long integer, ratio of number of packets with Ethernet FCS corrupted in all flows, expressed in ppm.""" ip_corrupted_pkt_ratio: int = field(XmpLong()) """long integer, ratio of number of packets with IP Header checksum corrupted in all flows, expressed in ppm.""" udp_corrupted_pkt_ratio: int = field(XmpLong()) """long integer, ratio of number of packets with UDP checksum corrupted in all flows, expressed in ppm.""" tcp_corrupted_pkt_ratio: int = field(XmpLong()) """long integer, ratio of number of packets with TCP checksum corrupted in all flows, expressed in ppm."""
[docs] def get(self) -> Token[GetDataAttr]: """Get statistics concerning all the packets corrupted on between this receive port and its partner TX port. :return: number of packets corrupted in all flows; number of packets with Ethernet FCS corrupted in all flows; number of packets with IP header checksum corrupted in all flows; number of packets with UDP checksum corrupted in all flows; number of packets with TCP checksum corrupted in all flows; ratio of number of packets corrupted in all flows, expressed in ppm; ratio of number of packets with Ethernet FCS corrupted in all flows expressed in ppm; ratio of number of packets with IP Header checksum corrupted in all flows, expressed in ppm; ratio of number of packets with UDP checksum corrupted in all flows, expressed in ppm; ratio of number of packets with TCP checksum corrupted in all flows, expressed in ppm :rtype: PE_CORTOTAL.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port))
[docs] @register_command @dataclass class PE_JITTERTOTAL: """ Obtains statistics concerning all the packets jittered between this receive port and its partner TX port. """ code: typing.ClassVar[int] = 1755 pushed: typing.ClassVar[bool] = False _connection: 'interfaces.IConnection' _module: int _port: int class GetDataAttr(ResponseBodyStruct): pkt_count: int = field(XmpLong()) """long integer, number of packets jittered in all flows.""" ratio: int = field(XmpLong()) """long integer, ratio of number of packets jittered in all flows expressed in ppm."""
[docs] def get(self) -> Token[GetDataAttr]: """Get statistics concerning all the packets jittered between this receive port and its partner TX port. :return: number of packets jittered in all flows, ratio of number of packets jittered in all flows expressed in ppm. :rtype: PE_JITTERTOTAL.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port))
[docs] @register_command @dataclass class PE_CLEAR: """ Clear all the impairment (duplicate, drop, mis-ordered, corrupted, latency and jitter) statistics for a Chimera port and flows on the port. The byte and packet counts will restart at zero. """ code: typing.ClassVar[int] = 1756 pushed: typing.ClassVar[bool] = False _connection: 'interfaces.IConnection' _module: int _port: int class SetDataAttr(RequestBodyStruct): pass
[docs] def set(self) -> Token[None]: """Clear all the impairment (duplicate, drop, mis-ordered, corrupted, latency and jitter) statistics for a Chimera port and flows on the port. The byte and packet counts will restart at zero. """ return Token(self._connection, build_set_request(self, module=self._module, port=self._port))
[docs] @register_command @dataclass class PE_FLOWDROPTOTAL: """ Obtains statistics concerning all the packets dropped in a flow between this receive port and its partner TX port. """ code: typing.ClassVar[int] = 1770 pushed: typing.ClassVar[bool] = False _connection: 'interfaces.IConnection' _module: int _port: int _flow_xindex: int class GetDataAttr(ResponseBodyStruct): pkt_drop_count_total: int = field(XmpLong()) """long integer, total number of packets dropped for the flow.""" pkt_drop_count_programmed: int = field(XmpLong()) """long integer, total number of packets dropped as programmed for the flow.""" pkt_drop_count_bandwidth: int = field(XmpLong()) """long integer, total number of packets dropped due to bandwidth control for the flow.""" pkt_drop_count_other: int = field(XmpLong()) """long integer, total number of packets dropped for other reasons for the flow.""" pkt_drop_ratio_total: int = field(XmpLong()) """long integer, ratio of number of packets dropped for the flow, expressed in ppm.""" pkt_drop_ratio_programmed: int = field(XmpLong()) """long integer, ratio of number of packets dropped as programmed for the flow, expressed in ppm.""" pkt_drop_ratio_bandwidth: int = field(XmpLong()) """long integer, ratio of number of packets dropped due to bandwidth control for the flow, expressed in ppm.""" pkt_drop_ratio_other: int = field(XmpLong()) """long integer, ratio of number of packets dropped for other reasons for the flow, expressed in ppm."""
[docs] def get(self) -> Token[GetDataAttr]: """Get statistics concerning all the packets dropped in a flow between this receive port and its partner TX port. :return: total number of packets dropped for the flow, total number of packets dropped as programmed for the flow, total number of packets dropped due to bandwidth control for the flow, total number of packets dropped for other reasons for the flow, ratio of number of packets dropped for the flow, expressed in ppm, ratio of number of packets dropped as programmed for the flow, expressed in ppm, ratio of number of packets dropped due to bandwidth control for the flow, expressed in ppm, ratio of number of packets dropped for other reasons for the flow, expressed in ppm. :rtype: PE_FLOWDROPTOTAL.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port, indices=[self._flow_xindex]))
[docs] @register_command @dataclass class PE_FLOWLATENCYTOTAL: """ Obtains statistics concerning all the packets delayed between this receive port and its partner TX port. """ code: typing.ClassVar[int] = 1771 pushed: typing.ClassVar[bool] = False _connection: 'interfaces.IConnection' _module: int _port: int _flow_xindex: int class GetDataAttr(ResponseBodyStruct): pkt_count: int = field(XmpLong()) """long integer, number of packets delayed in the flow.""" ratio: int = field(XmpLong()) """long integer, ratio of number of packets delayed in the flow, expressed in ppm."""
[docs] def get(self) -> Token[GetDataAttr]: """Get statistics concerning all the packets delayed between this receive port and its partner TX port. :return: number of packets delayed in the flow, ratio of number of packets delayed in the flow, expressed in ppm. :rtype: PE_FLOWLATENCYTOTAL.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port, indices=[self._flow_xindex]))
[docs] @register_command @dataclass class PE_FLOWDUPTOTAL: """ Obtains statistics concerning all the packets duplicated in a flow between this receive port and its partner TX port. """ code: typing.ClassVar[int] = 1772 pushed: typing.ClassVar[bool] = False _connection: 'interfaces.IConnection' _module: int _port: int _flow_xindex: int class GetDataAttr(ResponseBodyStruct): pkt_count: int = field(XmpLong()) """long integer, number of packets duplicated for the flow.""" ratio: int = field(XmpLong()) """long integer, ratio of number of packets duplicated for the flow - expressed in ppm."""
[docs] def get(self) -> Token[GetDataAttr]: """Get statistics concerning all the packets duplicated in a flow between this receive port and its partner TX port. :return: number of packets duplicated for the flow, ratio of number of packets duplicated for the flow - expressed in ppm. :rtype: PE_FLOWDUPTOTAL.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port, indices=[self._flow_xindex]))
[docs] @register_command @dataclass class PE_FLOWMISTOTAL: """ Obtains statistics concerning all the packets mis-ordered in a flow between this receive port and its partner TX port. """ code: typing.ClassVar[int] = 1773 pushed: typing.ClassVar[bool] = False _connection: 'interfaces.IConnection' _module: int _port: int _flow_xindex: int class GetDataAttr(ResponseBodyStruct): pkt_count: int = field(XmpLong()) """long integer, number of packets mis-ordered for the flow.""" ratio: int = field(XmpLong()) """long integer, ratio of number of packets, expressed in ppm."""
[docs] def get(self) -> Token[GetDataAttr]: """Get statistics concerning all the packets mis-ordered in a flow between this receive port and its partner TX port. :return: number of packets mis-ordered for the flow, ratio of number of packets, expressed in ppm. :rtype: PE_FLOWMISTOTAL.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port, indices=[self._flow_xindex]))
[docs] @register_command @dataclass class PE_FLOWCORTOTAL: """ Obtains statistics concerning all the packets corrupted in a flow between this receive port and its partner TX port. """ code: typing.ClassVar[int] = 1774 pushed: typing.ClassVar[bool] = False _connection: 'interfaces.IConnection' _module: int _port: int _flow_xindex: int class GetDataAttr(ResponseBodyStruct): total_corrupted_pkt_count: int = field(XmpLong()) """long integer, number of packets corrupted for the flow.""" fcs_corrupted_pkt_count: int = field(XmpLong()) """long integer, number of packets with Ethernet FCS corrupted for the flow.""" ip_corrupted_pkt_count: int = field(XmpLong()) """long integer, number of packets with IP header checksum corrupted for the flow.""" udp_corrupted_pkt_count: int = field(XmpLong()) """long integer, number of packets with UDP checksum corrupted for the flow.""" tcp_corrupted_pkt_count: int = field(XmpLong()) """long integer, number of packets with TCP checksum corrupted for the flow.""" total_corrupted_pkt_ratio: int = field(XmpLong()) """long integer, ratio of number of packets corrupted for the flow expressed in ppm.""" fcs_corrupted_pkt_ratio: int = field(XmpLong()) """long integer, ratio of number of packets with Ethernet FCS corrupted for the flow expressed in ppm.""" ip_corrupted_pkt_ratio: int = field(XmpLong()) """long integer, ratio of number of packets with IP Header checksum corrupted for the flow expressed in ppm.""" udp_corrupted_pkt_ratio: int = field(XmpLong()) """long integer, ratio of number of packets with UDP checksum corrupted for the flow expressed in ppm.""" tcp_corrupted_pkt_ratio: int = field(XmpLong()) """long integer, ratio of number of packets with TCP checksum corrupted for the flow expressed in ppm."""
[docs] def get(self) -> Token[GetDataAttr]: """Get statistics concerning all the packets corrupted in a flow between this receive port and its partner TX port. :return: number of packets corrupted for the flow, number of packets with Ethernet FCS corrupted for the flow, number of packets with IP header checksum corrupted for the flow, number of packets with UDP checksum corrupted for the flow, number of packets with TCP checksum corrupted for the flow, ratio of number of packets corrupted for the flow expressed in ppm, ratio of number of packets with Ethernet FCS corrupted for the flow expressed in ppm, ratio of number of packets with IP Header checksum corrupted for the flow expressed in ppm, ratio of number of packets with UDP checksum corrupted for the flow expressed in ppm, ratio of number of packets with TCP checksum corrupted for the flow expressed in ppm. :rtype: PE_FLOWCORTOTAL.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port, indices=[self._flow_xindex]))
[docs] @register_command @dataclass class PE_FLOWJITTERTOTAL: """ Obtains statistics concerning all the packets jittered in a flow between this receive port and its partner TX port. """ code: typing.ClassVar[int] = 1775 pushed: typing.ClassVar[bool] = False _connection: 'interfaces.IConnection' _module: int _port: int _flow_xindex: int class GetDataAttr(ResponseBodyStruct): pkt_count: int = field(XmpLong()) """long integer, number of packets jittered in the flow.""" ratio: int = field(XmpLong()) """long integer, ratio of number of packets jittered in the flow, expressed in ppm."""
[docs] def get(self) -> Token[GetDataAttr]: """Get statistics concerning all the packets jittered in a flow between this receive port and its partner TX port. :return: number of packets jittered in the flow, ratio of number of packets jittered in the flow, expressed in ppm :rtype: PE_FLOWJITTERTOTAL.GetDataAttr """ return Token(self._connection, build_get_request(self, module=self._module, port=self._port, indices=[self._flow_xindex]))
[docs] @register_command @dataclass class PE_FLOWCLEAR: """ Clear all the impairment (duplicate, drop, mis-ordered, corrupted, latency and jitter) statistics on a particular flow on the port. The byte and packet counts will restart at zero. """ code: typing.ClassVar[int] = 1776 pushed: typing.ClassVar[bool] = False _connection: 'interfaces.IConnection' _module: int _port: int _flow_xindex: int class SetDataAttr(RequestBodyStruct): pass
[docs] def set(self) -> Token[None]: """Clear all the impairment (duplicate, drop, mis-ordered, corrupted, latency and jitter) statistics on a particular flow on the port. The byte and packet counts will restart at zero. """ return Token(self._connection, build_set_request(self, module=self._module, port=self._port, indices=[self._flow_xindex]))