libcosmos
Linux C++ System Programming Library
Loading...
Searching...
No Matches
cosmos::UnixConnection Class Reference

An active UNIX domain socket connection. More...

#include <UnixConnection.hxx>

+ Inheritance diagram for cosmos::UnixConnection:

Public Member Functions

 UnixConnection (FileDescriptor fd, const AutoCloseFD auto_close=AutoCloseFD{true})
 
auto unixOptions ()
 
auto unixOptions () const
 
void sendMessage (SendMessageHeader &header)
 
Socket::AddressFilledIn receiveMessage (ReceiveMessageHeader &header)
 
size_t receive (void *buf, size_t length, const MessageFlags flags=MessageFlags{})
 Receive data from the socket, using specific receive flags.
 
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.
 
- Public Member Functions inherited from cosmos::Socket
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.
 
- Public Member Functions inherited from cosmos::FDFile
 FDFile (const FileDescriptor fd, const AutoCloseFD auto_close)
 Wrap the given file descriptor applying the specified auto-close behaviour.
 
 FDFile (FDFile &&other) noexcept
 
FDFileoperator= (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.
 
- Public Member Functions inherited from cosmos::FileBase
 FileBase (const FileBase &)=delete
 
FileBaseoperator= (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)
 
- Public Member Functions inherited from cosmos::StreamIO
 StreamIO (FileDescriptor &fd)
 
 StreamIO (const StreamIO &)=delete
 
StreamIOoperator= (const StreamIO &)=delete
 
StreamIOoperator= (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.
 

Additional Inherited Members

- Public Types inherited from cosmos::Socket
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.
 
- Public Types inherited from cosmos::StreamIO
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...
 
- Protected Member Functions inherited from cosmos::Socket
 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, AddressFilledInreceiveFrom (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.
 
- Protected Member Functions inherited from cosmos::FileBase
 FileBase (const FileDescriptor fd=FileDescriptor{})
 
 FileBase (FileBase &&other) noexcept
 
FileBaseoperator= (FileBase &&other) noexcept
 
- Protected Attributes inherited from cosmos::FDFile
AutoCloseFD m_auto_close
 
- Protected Attributes inherited from cosmos::FileBase
FileDescriptor m_fd
 
- Protected Attributes inherited from cosmos::StreamIO
FileDescriptorm_stream_fd
 

Detailed Description

An active UNIX domain socket connection.

Definition at line 12 of file UnixConnection.hxx.

Constructor & Destructor Documentation

◆ UnixConnection()

cosmos::UnixConnection::UnixConnection ( FileDescriptor fd,
const AutoCloseFD auto_close = AutoCloseFD{true} )
inlineexplicit

Definition at line 16 of file UnixConnection.hxx.

16 {true}) :
17 Socket{fd, auto_close} {
18 }
FileDescriptor fd() const
Allows access to the underlying fd with const semantics.
Definition FileBase.hxx:74
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.
Definition Socket.cxx:11

Member Function Documentation

◆ receive()

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.

84 {
85 const auto res = ::recv(to_integral(m_fd.raw()), buf, length, flags.raw());
86 if (res < 0) {
87 cosmos_throw(ApiError("recv()"));
88 }
89
90 return static_cast<size_t>(res);
91}
FileNum raw() const
Returns the primitive file descriptor contained in the object.

◆ receiveMessage()

Socket::AddressFilledIn cosmos::UnixConnection::receiveMessage ( ReceiveMessageHeader & header)
inline

Definition at line 35 of file UnixConnection.hxx.

35 {
36 return Socket::receiveMessage(header);
37 }
AddressFilledIn receiveMessage(ReceiveMessageHeader &header, SocketAddress *addr=nullptr)
Receives a message from the socket using extended ReceiveMessageHeader data.
Definition Socket.cxx:145

◆ send() [1/2]

size_t cosmos::Socket::send ( const std::string_view data,
const MessageFlags flags = MessageFlags{} )
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.

153 {}) {
154 return send(data.data(), data.size(), flags);
155 }
size_t send(const void *buf, size_t length, const MessageFlags flags=MessageFlags{})
Send the given data over the socket, using specific send flags.
Definition Socket.cxx:66

◆ send() [2/2]

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.

66 {
67 const auto res = ::send(to_integral(m_fd.raw()), buf, length, flags.raw());
68 if (res < 0) {
69 cosmos_throw(ApiError("send()"));
70 }
71
72 return static_cast<size_t>(res);
73}

◆ sendMessage()

void cosmos::UnixConnection::sendMessage ( SendMessageHeader & header)
inline

Definition at line 31 of file UnixConnection.hxx.

31 {
32 return Socket::sendMessage(header);
33 }
void sendMessage(SendMessageHeader &header, const SocketAddress *addr=nullptr)
Sends a message over the socket using extended SendMessageHeader data.
Definition Socket.cxx:126

◆ unixOptions() [1/2]

auto cosmos::UnixConnection::unixOptions ( )
inline

Definition at line 20 of file UnixConnection.hxx.

20 {
21 return UnixOptions{this->m_fd};
22 }

◆ unixOptions() [2/2]

auto cosmos::UnixConnection::unixOptions ( ) const
inline

Definition at line 24 of file UnixConnection.hxx.

24 {
25 return UnixOptions{this->m_fd};
26 }

The documentation for this class was generated from the following file: