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 36 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 37 of file SocketReader.cpp.

37 {
38 ssize_t ret = 0;
39
40 if ((SSL_get_shutdown(ssl) & SSL_RECEIVED_SHUTDOWN) != 0) {
41 ret = Super::read(chunk, chunkLen);
42 } else {
43 chunkLen = chunkLen > std::numeric_limits<int>::max() ? std::numeric_limits<int>::max() : chunkLen;
44 ret = SSL_read(ssl, chunk, static_cast<int>(chunkLen));
45
46 if (ret <= 0) {
47 const int ssl_err = SSL_get_error(ssl, static_cast<int>(ret));
48
49 switch (ssl_err) {
50 case SSL_ERROR_WANT_READ:
51 errno = EAGAIN;
52 ret = -1;
53 break;
54 case SSL_ERROR_WANT_WRITE:
55 LOG(TRACE) << getName() << " SSL/TLS: Start renegotiation on read";
57 [this]() {
58 LOG(DEBUG) << getName() << " SSL/TLS: Renegotiation on read success";
59 },
60 [this]() {
61 LOG(WARNING) << getName() << " SSL/TLS: Renegotiation on read timed out";
62 },
63 [this](int ssl_err) {
64 ssl_log(getName() + " SSL/TLS: Renegotiation on read", ssl_err);
65 });
66 errno = EAGAIN;
67 ret = -1;
68 break;
69 case SSL_ERROR_ZERO_RETURN: // received close_notify
70 LOG(DEBUG) << getName() << " SSL/TLS: Close_notify is" << (closeNotifyIsEOF ? " " : " not ") << "EOF";
72 errno = closeNotifyIsEOF ? 0 : EAGAIN;
73 ret = closeNotifyIsEOF ? 0 : -1;
74 break;
75 case SSL_ERROR_SYSCALL: // When SSL_get_error(ssl, ret) returns SSL_ERROR_SYSCALL
76 // and ret is 0, it indicates that the underlying TCP connection
77 // was closed unexpectedly by the peer. This situation typically
78 // happens when the peer closes (FIN) the connection without
79 // sending a close_notify alert, which violates the SSL/TLS
80 // protocol’s graceful shutdown procedure.
81 // In case ret is -1 a real syscall error (RST = ECONNRESET)
82 {
83 const utils::PreserveErrno pe;
84
85 if (ret == 0) {
86 PLOG(DEBUG) << getName() << " SSL/TLS: EOF detected: Connection closed by peer.";
87 } else {
88 PLOG(WARNING) << getName() + " SSL/TLS: Syscall error on read";
89 }
90 }
91 ret = -1;
92 break;
93 case SSL_ERROR_SSL:
94 ssl_log(getName() + " SSL/TLS: Read failed", ssl_err);
96 ret = -1;
97 break;
98 default:
99 ssl_log(getName() + " SSL/TLS: Unexpected error", ssl_err);
101 errno = EIO;
102 ret = -1;
103 break;
104 }
105 }
106 }
107
108 return ret;
109 }
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:31

Member Data Documentation

◆ closeNotifyIsEOF

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

Definition at line 52 of file SocketReader.h.

◆ ssl

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

Definition at line 50 of file SocketReader.h.


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