SNode.C
Loading...
Searching...
No Matches
core::socket::stream::tls::SocketWriter Class Referenceabstract

#include <SocketWriter.h>

Inheritance diagram for core::socket::stream::tls::SocketWriter:
Collaboration diagram for core::socket::stream::tls::SocketWriter:

Protected Member Functions

virtual bool doSSLHandshake (const std::function< void()> &onSuccess, const std::function< void()> &onTimeout, const std::function< void(int)> &onStatus)=0
 
- Protected Member Functions inherited from core::socket::stream::SocketWriter
 SocketWriter (const std::string &instanceName, const std::function< void(int)> &onStatus, const utils::Timeval &timeout, std::size_t blockSize, const utils::Timeval &terminateTimeout)
 
void setBlockSize (std::size_t writeBlockSize)
 
void sendToPeer (const char *chunk, std::size_t chunkLen)
 
bool streamToPeer (core::pipe::Source *source)
 
void streamEof ()
 
void shutdownWrite (const std::function< void()> &onShutdown)
 
- Protected Member Functions inherited from core::eventreceiver::WriteEventReceiver
 WriteEventReceiver (const std::string &name, const utils::Timeval &timeout)
 
virtual void writeTimeout ()
 
- Protected Member Functions inherited from core::DescriptorEventReceiver
bool enable (int fd)
 
void disable ()
 
void suspend ()
 
void resume ()
 
- Protected Member Functions inherited from core::Observer
void observed ()
 
void unObserved ()
 
virtual void unobservedEvent ()=0
 
 Observer ()=default
 
 Observer (Observer &)=delete
 
 Observer (Observer &&)=delete
 
virtual ~Observer ()
 
- Protected Member Functions inherited from core::EventReceiver
virtual ~EventReceiver ()=default
 
 EventReceiver (const std::string &name)
 
 EventReceiver (EventReceiver &)=delete
 
 EventReceiver (EventReceiver &&)=delete
 
EventReceiveroperator= (EventReceiver &)=delete
 
EventReceiveroperator= (EventReceiver &&)=delete
 
virtual void destruct ()
 
void span ()
 
void relax ()
 
const std::string & getName () const
 

Protected Attributes

SSL * ssl = nullptr
 
bool closeNotifyIsEOF = true
 
- Protected Attributes inherited from core::socket::stream::SocketWriter
bool markShutdown = false
 
std::function< void()> onShutdown
 
std::vector< char > writePuffer
 
bool shutdownInProgress = false
 
utils::Timeval terminateTimeout
 

Private Types

using Super = core::socket::stream::SocketWriter
 

Private Member Functions

ssize_t write (const char *chunk, std::size_t chunkLen) override
 

Additional Inherited Members

- Public Member Functions inherited from core::socket::stream::SocketWriter
 SocketWriter ()=delete
 
- Public Member Functions inherited from core::DescriptorEventReceiver
 DescriptorEventReceiver (const std::string &name, DescriptorEventPublisher &descriptorEventPublisher, const utils::Timeval &timeout=TIMEOUT::DISABLE)
 
int getRegisteredFd () const
 
bool isEnabled () const
 
bool isSuspended () const
 
void setTimeout (const utils::Timeval &timeout)
 
utils::Timeval getTimeout (const utils::Timeval &currentTime) const
 
void checkTimeout (const utils::Timeval &currentTime)
 
- Public Member Functions inherited from core::EventReceiver
 EventReceiver (const std::string &name)
 
 EventReceiver (EventReceiver &)=delete
 
 EventReceiver (EventReceiver &&)=delete
 
EventReceiveroperator= (EventReceiver &)=delete
 
EventReceiveroperator= (EventReceiver &&)=delete
 
virtual void destruct ()
 
void span ()
 
void relax ()
 
const std::string & getName () const
 
- Static Public Member Functions inherited from core::EventReceiver
static void atNextTick (const std::function< void(void)> &callBack)
 
- Static Protected Member Functions inherited from core::EventReceiver
static void atNextTick (const std::function< void(void)> &callBack)
 

Detailed Description

Definition at line 36 of file SocketWriter.h.

Member Typedef Documentation

◆ Super

Member Function Documentation

◆ doSSLHandshake()

virtual bool core::socket::stream::tls::SocketWriter::doSSLHandshake ( const std::function< void()> & onSuccess,
const std::function< void()> & onTimeout,
const std::function< void(int)> & onStatus )
protectedpure virtual

◆ write()

ssize_t core::socket::stream::tls::SocketWriter::write ( const char * chunk,
std::size_t chunkLen )
overrideprivatevirtual

Reimplemented from core::socket::stream::SocketWriter.

Definition at line 36 of file SocketWriter.cpp.

36 {
37 ssize_t ret = 0;
38
39 if ((SSL_get_shutdown(ssl) & SSL_SENT_SHUTDOWN) != 0) {
40 ret = Super::write(chunk, chunkLen);
41 } else {
42 ret = SSL_write(ssl, chunk, static_cast<int>(chunkLen));
43
44 if (ret <= 0) {
45 const int ssl_err = SSL_get_error(ssl, static_cast<int>(ret));
46
47 switch (ssl_err) {
48 case SSL_ERROR_WANT_READ:
49 LOG(TRACE) << getName() << " SSL/TLS: Start renegotiation on read";
51 [this]() {
52 LOG(DEBUG) << getName() << " SSL/TLS: Renegotiation on read success";
53 },
54 [this]() {
55 LOG(WARNING) << getName() << " SSL/TLS: Renegotiation on read timed out";
56 },
57 [this](int ssl_err) {
58 ssl_log(getName() + " SSL/TLS: Renegotiation", ssl_err);
59 });
60 errno = EAGAIN;
61 ret = -1;
62 break;
63 case SSL_ERROR_WANT_WRITE:
64 errno = EAGAIN;
65 ret = -1;
66 break;
67 case SSL_ERROR_ZERO_RETURN: // shutdown cleanly
68 LOG(DEBUG) << getName() << " SSL/TLS: Close_notify received. Is EOF? " << (closeNotifyIsEOF ? "true" : "false");
69 errno = closeNotifyIsEOF ? EPIPE : EAGAIN;
70 ret = -1; // on the write side this means a TCP broken pipe
71 break;
72 case SSL_ERROR_SYSCALL:
73 // In case ret is -1 a real syscall error (RST = ECONNRESET)
74 {
75 const utils::PreserveErrno pe;
76
77 if (errno == EPIPE) {
78 PLOG(WARNING) << getName() << " SSL/TLS: Syscal error (SIGPIPE detected) on write.";
79 } else if (errno == ECONNRESET) {
80 PLOG(WARNING) << getName() << " SSL/TLS: Connection reset by peer (ECONNRESET).";
81 } else {
82 PLOG(WARNING) << getName() << " SSL/TLS: Syscall error on write";
83 }
84 }
85 ret = -1;
86 break;
87 case SSL_ERROR_SSL:
88 ssl_log(getName() + " SSL/TLS: Failed", ssl_err);
89 ret = -1;
90 break;
91 default:
92 ssl_log(getName() + " SSL/TLS: Unexpected error", ssl_err);
93 errno = EIO;
94 ret = -1;
95 break;
96 }
97 }
98 }
99
100 return ret;
101 }
const std::string & getName() const
virtual ssize_t write(const char *chunk, std::size_t chunkLen)
virtual bool doSSLHandshake(const std::function< void()> &onSuccess, const std::function< void()> &onTimeout, const std::function< void(int)> &onStatus)=0
void ssl_log(const std::string &message, int sslErr)
int SSL_write(SSL *ssl, const void *buf, int num)
Definition ssl.cpp:36

Member Data Documentation

◆ closeNotifyIsEOF

bool core::socket::stream::tls::SocketWriter::closeNotifyIsEOF = true
protected

Definition at line 50 of file SocketWriter.h.

◆ ssl

SSL* core::socket::stream::tls::SocketWriter::ssl = nullptr
protected

Definition at line 48 of file SocketWriter.h.


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