libcosmos
Linux C++ System Programming Library
|
Template class for IPv4 and IPv6 based UDP datagram sockets. More...
#include <UDPSocket.hxx>
Public Types | |
using | IPAddress = typename IPSocketT<FAMILY>::IPAddress |
![]() | |
using | IPAddress = typename FamilyTraits<FAMILY>::Address |
![]() | |
enum class | Direction : int { READ = SHUT_RD , WRITE = SHUT_WR , READ_WRITE = SHUT_RDWR } |
Type used in Socket::shutdown(). More... | |
using | AddressFilledIn = NamedBool<struct addr_filled_in_t, false> |
Boolean flag used in receiveFrom() to signify if a peer address could be provided. | |
![]() | |
enum class | SeekType : int { SET = SEEK_SET , CUR = SEEK_CUR , END = SEEK_END , DATA = SEEK_DATA , HOLE = SEEK_HOLE } |
Different methods for changing the file read/write position. More... | |
Public Member Functions | |
UDPSocketT (const SocketFlags flags=SocketFlags{SocketFlag::CLOEXEC}) | |
auto | udpOptions () |
auto | udpOptions () const |
void | bind (const IPAddress &addr) |
Bind to the given IP address. | |
void | connect (const IPAddress &addr) |
Connect to the given IP address. | |
std::pair< size_t, std::optional< IPAddress > > | receiveFrom (void *buf, size_t length, const MessageFlags flags=MessageFlags{}) |
Receive data and get the sender's IP address. | |
auto | sendTo (const void *buf, size_t length, const IPAddress &addr, const MessageFlags flags=MessageFlags{}) |
Send data to a specific IP address. | |
auto | sendTo (const std::string_view data, const IPAddress &addr, const MessageFlags flags=MessageFlags{}) |
void | sendMessage (SendMessageHeader &header) |
void | sendMessageTo (SendMessageHeader &header, const IPAddress &addr) |
void | receiveMessage (ReceiveMessageHeader &header) |
std::optional< IPAddress > | receiveMessageFrom (ReceiveMessageHeader &header) |
size_t | send (const void *buf, size_t length, const MessageFlags flags=MessageFlags{}) |
Send the given data over the socket, using specific send flags. | |
size_t | send (const std::string_view data, const MessageFlags flags=MessageFlags{}) |
Variant of send() that takes a std::string_view container instead of a raw input buffer. | |
size_t | receive (void *buf, size_t length, const MessageFlags flags=MessageFlags{}) |
Receive data from the socket, using specific receive flags. | |
![]() | |
auto | ipOptions () |
auto | ipOptions () const |
void | getSockName (IPAddress &addr) |
Returns the current address that the socket is bound to, if any. | |
![]() | |
auto | sockOptions () |
auto | sockOptions () const |
void | getSockName (SocketAddress &addr) |
Returns the current address that the socket is bound to, if any. | |
void | shutdown (const Direction dir) |
Shutdown part or all of the connection on protocol level. | |
![]() | |
FDFile (const FileDescriptor fd, const AutoCloseFD auto_close) | |
Wrap the given file descriptor applying the specified auto-close behaviour. | |
FDFile (FDFile &&other) noexcept | |
FDFile & | operator= (FDFile &&other) noexcept |
void | open (const FileDescriptor fd, const AutoCloseFD auto_close) |
Takes the already open file descriptor fd and operates on it. | |
void | close () override |
Close the current file object. | |
![]() | |
FileBase (const FileBase &)=delete | |
FileBase & | operator= (const FileBase &)=delete |
bool | isOpen () const |
Returns whether currently a FileDescriptor is opened. | |
FileDescriptor | fd () const |
Allows access to the underlying fd with const semantics. | |
void | truncate (const off_t length) |
![]() | |
StreamIO (FileDescriptor &fd) | |
StreamIO (const StreamIO &)=delete | |
StreamIO & | operator= (const StreamIO &)=delete |
StreamIO & | operator= (StreamIO &&) noexcept |
size_t | read (void *buf, size_t length) |
Read up to length bytes from the file into buf . | |
size_t | write (const void *buf, size_t length) |
Write up to length bytes from buf into the underlying file. | |
size_t | write (const std::string_view data) |
string_view wrapper around write(const void*, size_t). | |
void | readAll (void *buf, size_t length) |
Read all length bytes from the underlying file. | |
void | readAll (std::string &s, size_t length) |
Like readAll(void*, size_t) using an STL string. | |
void | writeAll (const void *buf, size_t length) |
Write all length bytes into the underlying file. | |
void | writeAll (const std::string_view data) |
string_view wrapper around writeAll(const void*, size_t). | |
bool | read (ReadIOVector &iovec) |
Read data from file into a vector of data regions. | |
bool | write (WriteIOVector &iovec) |
Write data to file from a vector of data regions. | |
void | readAll (ReadIOVector &iovec) |
Read into all data regions specified in iovec . | |
void | writeAll (WriteIOVector &iovec) |
Write all data regions specified in iovec . | |
off_t | seek (const SeekType type, off_t off) |
Seek to the given offset based on the given offset type . | |
off_t | seekFromStart (off_t off) |
Seek to the given offset relative to the start of the file. | |
off_t | seekFromCurrent (off_t off) |
Seek to the given offset relative to the current file position. | |
off_t | seekFromEnd (off_t off) |
Seek to the given offset relative to the end of the file. | |
Static Public Attributes | |
static constexpr auto | TYPE = SocketType::DGRAM |
Additional Inherited Members | |
![]() | |
IPSocketT (const SocketType type, const SocketFlags flags=SocketFlags{SocketFlag::CLOEXEC}, const SocketProtocol protocol=SocketProtocol::DEFAULT) | |
IPSocketT (FileDescriptor fd, const AutoCloseFD auto_close) | |
![]() | |
Socket (const SocketFamily family, const SocketType type, const SocketFlags flags=SocketFlags{SocketFlag::CLOEXEC}, const SocketProtocol protocol=SocketProtocol::DEFAULT) | |
Creates a new socket using the given properties. | |
Socket (FileDescriptor fd, const AutoCloseFD auto_close) | |
Creates a new socket from the given existing file descriptor. | |
void | bind (const SocketAddress &addr) |
Bind the socket to the given local address. | |
void | connect (const SocketAddress &addr) |
Establish a new connection using the given destination address. | |
void | listen (const size_t backlog) |
Enter into a passive listen state, allowing new connections. | |
FileDescriptor | accept (SocketAddress *addr) |
Accept a new connection on the socket. | |
size_t | send (const void *buf, size_t length, const MessageFlags flags=MessageFlags{}) |
Send the given data over the socket, using specific send flags. | |
size_t | send (const std::string_view data, const MessageFlags flags=MessageFlags{}) |
Variant of send() that takes a std::string_view container instead of a raw input buffer. | |
size_t | sendTo (const void *buf, size_t length, const SocketAddress &addr, const MessageFlags flags=MessageFlags{}) |
Send a packet to a specific destination address. | |
size_t | sendTo (const std::string_view data, const SocketAddress &addr, const MessageFlags flags=MessageFlags{}) |
Variant of sendTo() that takes a std::string_view container instead of a raw input buffer. | |
void | sendMessage (SendMessageHeader &header, const SocketAddress *addr=nullptr) |
Sends a message over the socket using extended SendMessageHeader data. | |
size_t | receive (void *buf, size_t length, const MessageFlags flags=MessageFlags{}) |
Receive data from the socket, using specific receive flags. | |
std::pair< size_t, AddressFilledIn > | receiveFrom (void *buf, size_t length, SocketAddress &addr, const MessageFlags flags=MessageFlags{}) |
Receive a packet, filling in the sender's address. | |
AddressFilledIn | receiveMessage (ReceiveMessageHeader &header, SocketAddress *addr=nullptr) |
Receives a message from the socket using extended ReceiveMessageHeader data. | |
![]() | |
FileBase (const FileDescriptor fd=FileDescriptor{}) | |
FileBase (FileBase &&other) noexcept | |
FileBase & | operator= (FileBase &&other) noexcept |
![]() | |
AutoCloseFD | m_auto_close |
![]() | |
FileDescriptor | m_fd |
![]() | |
FileDescriptor & | m_stream_fd |
Template class for IPv4 and IPv6 based UDP datagram sockets.
Use cosmos::UDP4Socket for the IPv4 variant and cosmos::UDP6Socket for the IPv6 variant of this type. This type offers access to UDP socket specific socket options. Furthermore it makes the bind() and connect() functions accessible for their respective IP address type.
The send and receive I/O functions are also available to send and receive datagrams using specific MessageFlags.
Definition at line 24 of file UDPSocket.hxx.
using cosmos::UDPSocketT< FAMILY >::IPAddress = typename IPSocketT<FAMILY>::IPAddress |
Definition at line 28 of file UDPSocket.hxx.
|
inlineexplicit |
Definition at line 33 of file UDPSocket.hxx.
|
inline |
Bind to the given IP address.
To receive packets, the UDP socket can be bound to a local address and port. If this is not done then the kernel with bind to IP4_ANY_ADDR and a free local port from the ip_local_port_range
found in /proc.
Definition at line 54 of file UDPSocket.hxx.
|
inline |
Connect to the given IP address.
By connecting a UDP socket a default destination is configured. After this is done a regular write() or send() can be used to send to this default destination.
The sendTo() method can still be used to send to a specific address.
Definition at line 69 of file UDPSocket.hxx.
size_t cosmos::Socket::receive | ( | void * | buf, |
size_t | length, | ||
const MessageFlags | flags = MessageFlags{} ) |
Receive data from the socket, using specific receive flags.
This is like a regular read() call but allows to specify socket specific MessageFlags to adjust various behaviour.
Definition at line 204 of file Socket.cxx.
|
inline |
Receive data and get the sender's IP address.
If possible the senders IP address will be returned. This may not be possible in which case std::nullopt will be returned instead.
Definition at line 80 of file UDPSocket.hxx.
|
inline |
Definition at line 111 of file UDPSocket.hxx.
|
inline |
Definition at line 115 of file UDPSocket.hxx.
|
inline |
Variant of send() that takes a std::string_view container instead of a raw input buffer.
Definition at line 153 of file Socket.hxx.
size_t cosmos::Socket::send | ( | const void * | buf, |
size_t | length, | ||
const MessageFlags | flags = MessageFlags{} ) |
Send the given data over the socket, using specific send flags.
This is like a regular write() call but allows to specify socket specific MessageFlags to adjust various behaviour.
Definition at line 150 of file Socket.cxx.
|
inline |
Definition at line 103 of file UDPSocket.hxx.
|
inline |
Definition at line 107 of file UDPSocket.hxx.
|
inline |
Definition at line 96 of file UDPSocket.hxx.
|
inline |
Send data to a specific IP address.
Definition at line 92 of file UDPSocket.hxx.
|
inline |
Definition at line 37 of file UDPSocket.hxx.
|
inline |
Definition at line 41 of file UDPSocket.hxx.
|
inlinestaticconstexpr |
Definition at line 29 of file UDPSocket.hxx.