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

#include <SocketReader.h>

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

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::SocketReader
 SocketReader (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 readBlockSize)
 
std::size_t readFromPeer (char *chunk, std::size_t chunkLen)
 
void shutdownRead ()
 
- Protected Member Functions inherited from core::eventreceiver::ReadEventReceiver
 ReadEventReceiver (const std::string &name, const utils::Timeval &timeout)
 
virtual void readTimeout ()
 
- 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::SocketReader
utils::Timeval terminateTimeout
 

Private Types

using Super = core::socket::stream::SocketReader
 

Private Member Functions

ssize_t read (char *chunk, std::size_t chunkLen) override
 
virtual void onReadShutdown ()=0
 

Additional Inherited Members

- Public Member Functions inherited from core::socket::stream::SocketReader
 SocketReader ()=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 58 of file SocketReader.h.

Member Typedef Documentation

◆ Super

Member Function Documentation

◆ doSSLHandshake()

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

◆ onReadShutdown()

virtual void core::socket::stream::tls::SocketReader::onReadShutdown ( )
privatepure virtual

◆ read()

ssize_t core::socket::stream::tls::SocketReader::read ( char * chunk,
std::size_t chunkLen )
overrideprivatevirtual

Reimplemented from core::socket::stream::SocketReader.

Definition at line 59 of file SocketReader.cpp.

59 {
60 ssize_t ret = 0;
61
62 if ((SSL_get_shutdown(ssl) & SSL_RECEIVED_SHUTDOWN) != 0) {
63 ret = Super::read(chunk, chunkLen);
64 } else {
65 chunkLen = chunkLen > std::numeric_limits<int>::max() ? std::numeric_limits<int>::max() : chunkLen;
66 ret = SSL_read(ssl, chunk, static_cast<int>(chunkLen));
67
68 if (ret <= 0) {
69 const int ssl_err = SSL_get_error(ssl, static_cast<int>(ret));
70
71 switch (ssl_err) {
72 case SSL_ERROR_WANT_READ:
73 errno = EAGAIN;
74 ret = -1;
75 break;
76 case SSL_ERROR_WANT_WRITE:
77 LOG(TRACE) << getName() << " SSL/TLS: Start renegotiation on read";
79 [this]() {
80 LOG(DEBUG) << getName() << " SSL/TLS: Renegotiation on read success";
81 },
82 [this]() {
83 LOG(WARNING) << getName() << " SSL/TLS: Renegotiation on read timed out";
84 },
85 [this](int ssl_err) {
86 ssl_log(getName() + " SSL/TLS: Renegotiation on read", ssl_err);
87 });
88 errno = EAGAIN;
89 ret = -1;
90 break;
91 case SSL_ERROR_ZERO_RETURN: // received close_notify
92 LOG(DEBUG) << getName() << " SSL/TLS: Close_notify is" << (closeNotifyIsEOF ? " " : " not ") << "EOF";
94 errno = closeNotifyIsEOF ? 0 : EAGAIN;
95 ret = closeNotifyIsEOF ? 0 : -1;
96 break;
97 case SSL_ERROR_SYSCALL: // When SSL_get_error(ssl, ret) returns SSL_ERROR_SYSCALL
98 // and ret is 0, it indicates that the underlying TCP connection
99 // was closed unexpectedly by the peer. This situation typically
100 // happens when the peer closes (FIN) the connection without
101 // sending a close_notify alert, which violates the SSL/TLS
102 // protocol’s graceful shutdown procedure.
103 // In case ret is -1 a real syscall error (RST = ECONNRESET)
104 {
105 const utils::PreserveErrno pe;
106
107 if (ret == 0) {
108 PLOG(DEBUG) << getName() << " SSL/TLS: EOF detected: Connection closed by peer.";
109 } else {
110 PLOG(WARNING) << getName() + " SSL/TLS: Syscall error on read";
111 }
112 }
113 ret = -1;
114 break;
115 case SSL_ERROR_SSL:
116 ssl_log(getName() + " SSL/TLS: Read failed", ssl_err);
118 ret = -1;
119 break;
120 default:
121 ssl_log(getName() + " SSL/TLS: Unexpected error", ssl_err);
123 errno = EIO;
124 ret = -1;
125 break;
126 }
127 }
128 }
129
130 return ret;
131 }
const std::string & getName() const
virtual ssize_t read(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_read(SSL *ssl, void *buf, int num)
Definition ssl.cpp:53

Member Data Documentation

◆ closeNotifyIsEOF

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

Definition at line 74 of file SocketReader.h.

◆ ssl

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

Definition at line 72 of file SocketReader.h.


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