|
libtins
4.0
|
Represents an UDP PDU. More...
#include <udp.h>
Public Member Functions | |
| UDP (uint16_t dport=0, uint16_t sport=0) | |
| UDP constructor. More... | |
| UDP (const uint8_t *buffer, uint32_t total_sz) | |
| Constructs an UDP object from a buffer. More... | |
| uint16_t | dport () const |
| Getter for the destination port. More... | |
| uint16_t | sport () const |
| Getter for the source port. More... | |
| uint16_t | length () const |
| Getter for the length of the datagram. More... | |
| uint16_t | checksum () const |
| Getter for the checksum of the datagram. More... | |
| void | dport (uint16_t new_dport) |
| Set the destination port. More... | |
| void | sport (uint16_t new_sport) |
| Set the source port. More... | |
| void | length (uint16_t new_len) |
| Set the length field. More... | |
| bool | matches_response (const uint8_t *ptr, uint32_t total_sz) const |
| Check whether ptr points to a valid response for this PDU. More... | |
| uint32_t | header_size () const |
| Returns the header size. More... | |
| PDUType | pdu_type () const |
| Getter for the PDU's type. More... | |
| UDP * | clone () const |
Public Member Functions inherited from Tins::PDU | |
| PDU () | |
| Default constructor. | |
| PDU (PDU &&rhs) TINS_NOEXCEPT | |
| Move constructor. More... | |
| PDU & | operator= (PDU &&rhs) TINS_NOEXCEPT |
| Move assignment operator. More... | |
| virtual | ~PDU () |
| PDU destructor. More... | |
| virtual uint32_t | trailer_size () const |
| Trailer's size. More... | |
| uint32_t | size () const |
| The whole chain of PDU's size, including this one. More... | |
| PDU * | inner_pdu () const |
| Getter for the inner PDU. More... | |
| PDU * | parent_pdu () const |
| PDU * | release_inner_pdu () |
| Releases the inner PDU. More... | |
| void | inner_pdu (PDU *next_pdu) |
| Sets the child PDU. More... | |
| void | inner_pdu (const PDU &next_pdu) |
| Sets the child PDU. More... | |
| serialization_type | serialize () |
| Serializes the whole chain of PDU's, including this one. More... | |
| template<typename T > | |
| T * | find_pdu (PDUType type=T::pdu_flag) |
| Finds and returns the first PDU that matches the given flag. More... | |
| template<typename T > | |
| const T * | find_pdu (PDUType type=T::pdu_flag) const |
| Finds and returns the first PDU that matches the given flag. More... | |
| template<typename T > | |
| T & | rfind_pdu (PDUType type=T::pdu_flag) |
| Finds and returns the first PDU that matches the given flag. More... | |
| template<typename T > | |
| const T & | rfind_pdu (PDUType type=T::pdu_flag) const |
| Finds and returns the first PDU that matches the given flag. More... | |
| virtual void | send (PacketSender &sender, const NetworkInterface &iface) |
| Send the stack of PDUs through a PacketSender. More... | |
| virtual PDU * | recv_response (PacketSender &sender, const NetworkInterface &iface) |
| Receives a matching response for this packet. More... | |
| virtual bool | matches_flag (PDUType flag) const |
| Check whether this PDU matches the specified flag. More... | |
Static Public Member Functions | |
| static metadata | extract_metadata (const uint8_t *buffer, uint32_t total_sz) |
| Extracts metadata for this protocol based on the buffer provided. More... | |
Static Public Attributes | |
| static const PDU::PDUType | pdu_flag = PDU::UDP |
| This PDU's flag. | |
Static Public Attributes inherited from Tins::PDU | |
| static const endian_type | endianness = BE |
Additional Inherited Members | |
Public Types inherited from Tins::PDU | |
| enum | endian_type { BE, LE } |
| enum | PDUType { RAW, ETHERNET_II, IEEE802_3, DOT3 = IEEE802_3, RADIOTAP, DOT11, DOT11_ACK, DOT11_ASSOC_REQ, DOT11_ASSOC_RESP, DOT11_AUTH, DOT11_BEACON, DOT11_BLOCK_ACK, DOT11_BLOCK_ACK_REQ, DOT11_CF_END, DOT11_DATA, DOT11_CONTROL, DOT11_DEAUTH, DOT11_DIASSOC, DOT11_END_CF_ACK, DOT11_MANAGEMENT, DOT11_PROBE_REQ, DOT11_PROBE_RESP, DOT11_PS_POLL, DOT11_REASSOC_REQ, DOT11_REASSOC_RESP, DOT11_RTS, DOT11_QOS_DATA, LLC, SNAP, IP, ARP, TCP, UDP, ICMP, BOOTP, DHCP, EAPOL, RC4EAPOL, RSNEAPOL, DNS, LOOPBACK, IPv6, ICMPv6, SLL, DHCPv6, DOT1Q, PPPOE, STP, PPI, IPSEC_AH, IPSEC_ESP, PKTAP, MPLS, UNKNOWN = 999, USER_DEFINED_PDU = 1000 } |
| Enum which identifies each type of PDU. More... | |
| typedef byte_array | serialization_type |
Protected Member Functions inherited from Tins::PDU | |
| PDU (const PDU &other) | |
| Copy constructor. | |
| PDU & | operator= (const PDU &other) |
| Copy assignment operator. | |
| void | copy_inner_pdu (const PDU &pdu) |
| Copy other PDU's inner PDU(if any). More... | |
| virtual void | prepare_for_serialize () |
| Prepares this PDU for serialization. More... | |
| void | serialize (uint8_t *buffer, uint32_t total_sz) |
| Serializes this PDU and propagates this action to child PDUs. More... | |
Represents an UDP PDU.
This class represents an UDP PDU.
While sniffing, the payload sent in each packet will be wrapped in a RawPDU, which is set as the UDP object's inner_pdu. Therefore, if you are sniffing and want to see the UDP packet's payload, you need to do the following:
| Tins::UDP::UDP | ( | uint16_t | dport = 0, |
| uint16_t | sport = 0 |
||
| ) |
| Tins::UDP::UDP | ( | const uint8_t * | buffer, |
| uint32_t | total_sz | ||
| ) |
Constructs an UDP object from a buffer.
If there is not enough size for a UDP header a malformed_packet exception is thrown.
Any extra data will be stored in a RawPDU.
| buffer | The buffer from which this PDU will be constructed. |
| total_sz | The total size of the buffer. |
|
inline |
Getter for the checksum of the datagram.
|
inlinevirtual |
Implements Tins::PDU.
|
inline |
Getter for the destination port.
| void Tins::UDP::dport | ( | uint16_t | new_dport | ) |
Set the destination port.
| new_dport | The new destination port. |
|
static |
Extracts metadata for this protocol based on the buffer provided.
| buffer | Pointer to a buffer |
| total_sz | Size of the buffer pointed by buffer |
|
virtual |
Returns the header size.
This method overrides PDU::header_size. This size includes the payload and options size.
Implements Tins::PDU.
|
inline |
Getter for the length of the datagram.
| void Tins::UDP::length | ( | uint16_t | new_len | ) |
Set the length field.
| new_len | The new length field. |
|
virtual |
Check whether ptr points to a valid response for this PDU.
This compares the source and destination ports in the provided response with those stored in this PDU.
| ptr | The pointer to the buffer. |
| total_sz | The size of the buffer. |
Reimplemented from Tins::PDU.
|
inlinevirtual |
|
inline |
Getter for the source port.
| void Tins::UDP::sport | ( | uint16_t | new_sport | ) |
Set the source port.
| new_sport | The new source port. |
1.8.11