Source code for pcapkit.foundation.reassembly.data.ip

# -*- coding: utf-8 -*-
"""data models for IP reassembly"""

from typing import TYPE_CHECKING, Generic, TypeVar

from pcapkit.corekit.infoclass import Info, info_final
from pcapkit.utilities.compat import Tuple

__all__ = [
    'Packet', 'DatagramID', 'Datagram', 'Buffer', 'BufferID',
]

if TYPE_CHECKING:
    from ipaddress import IPv4Address, IPv6Address
    from typing import Optional, overload

    from typing_extensions import Literal, TypeAlias

    from pcapkit.const.reg.transtype import TransType
    from pcapkit.protocols.protocol import ProtocolBase as Protocol

_AT = TypeVar('_AT', 'IPv4Address', 'IPv6Address')

#: Buffer ID.
BufferID: 'TypeAlias' = Tuple[_AT, _AT, int, 'TransType']


[docs] @info_final class Packet(Info, Generic[_AT]): """Data model for :term:`IPv4 <reasm.ipv4.packet>` and/or :term:`IPv6 <reasm.ipv6.packet>` packet representation..""" #: Buffer ID. bufid: 'BufferID' #: Original packet range number. num: 'int' #: Fragment offset. fo: 'int' #: Internet header length. ihl: 'int' #: More fragments flag. mf: 'bool' #: Total length, header included. tl: 'int' #: Raw :obj:`bytes` type header. header: 'bytes' #: Raw :obj:`bytearray` type payload. payload: 'bytearray' if TYPE_CHECKING: def __init__(self, bufid: 'tuple[_AT, _AT, int, TransType]', num: 'int', fo: 'int', ihl: 'int', mf: 'bool', tl: 'int', header: 'bytes', payload: 'bytearray') -> 'None': ... # pylint: disable=unused-argument,super-init-not-called,multiple-statements,line-too-long,redefined-builtin
[docs] @info_final class DatagramID(Info, Generic[_AT]): """Data model for :term:`IPv4 <reasm.ipv4.datagram>` and/or :term:`IPv6 <reasm.ipv6.datagram>` original packet identifier.""" #: Source address. src: '_AT' #: Destination address. dst: '_AT' #: IP protocol identifier. id: 'int' #: Payload protocol type. proto: 'TransType' if TYPE_CHECKING: def __init__(self, src: '_AT', dst: '_AT', id: 'int', proto: 'TransType') -> 'None': ... # pylint: disable=unused-argument,super-init-not-called,multiple-statements,line-too-long,redefined-builtin
[docs] @info_final class Datagram(Info, Generic[_AT]): """Data model for :term:`IPv4 <reasm.ipv4.datagram>` and/or :term:`IPv6 <reasm.ipv6.datagram>` reassembled datagram.""" #: Completed flag. completed: 'bool' #: Original packet identifier. id: 'DatagramID[_AT]' #: Packet numbers. index: 'tuple[int, ...]' #: Initial IP header. header: 'bytes' #: Reassembled IP payload. payload: 'bytes | tuple[bytes, ...]' #: Parsed IP payload. packet: 'Optional[Protocol]' if TYPE_CHECKING: @overload #pylint: disable=used-before-assignment def __init__(self, completed: 'Literal[True]', id: 'DatagramID[_AT]', index: 'tuple[int, ...]', header: 'bytes', payload: 'bytes', packet: 'Protocol') -> 'None': ... # pylint: disable=unused-argument,super-init-not-called,multiple-statements,line-too-long,redefined-builtin @overload def __init__(self, completed: 'Literal[False]', id: 'DatagramID[_AT]', index: 'tuple[int, ...]', header: 'bytes', payload: 'tuple[bytes, ...]', packet: 'None') -> 'None': ... # pylint: disable=unused-argument,super-init-not-called,multiple-statements,line-too-long,redefined-builtin def __init__(self, completed: 'bool', id: 'DatagramID[_AT]', index: 'tuple[int, ...]', header: 'bytes', payload: 'bytes | tuple[bytes, ...]', packet: 'Optional[Protocol]') -> 'None': ... # pylint: disable=unused-argument,super-init-not-called,multiple-statements,line-too-long,redefined-builtin
[docs] @info_final class Buffer(Info, Generic[_AT]): """Data model for :term:`IPv4 <reasm.ipv4.buffer>` and/or :term:`IPv6 <reasm.ipv6.buffer>` reassembly buffer entry.""" #: Total data length. TDL: 'int' #: Fragment received bit table. RCVBT: 'bytearray' #: List of reassembled packets. index: 'list[int]' #: Header buffer. header: 'bytes' #: Data buffer, holes set to ``b'\x00'``. datagram: 'bytearray' if TYPE_CHECKING: def __init__(self, TDL: 'int', RCVBT: 'bytearray', index: 'list[int]', header: 'bytes', datagram: 'bytearray') -> 'None': ... # pylint: disable=unused-argument,super-init-not-called,multiple-statements,line-too-long,redefined-builtin