![]() |
TSDuck v3.45-4709
MPEG Transport Stream Toolkit
|
SSL/TLS connected socket for use in a Reactor environment. More...
#include <tsReactiveTLSConnection.h>


Public Member Functions | |
| ReactiveTLSConnection (Reactor &reactor, TCPConnection &socket, const TLSArgs &args, Object *owner=nullptr) | |
| Constructor with initial client arguments. | |
| ReactiveTLSConnection (Reactor &reactor, TCPConnection &socket, Object *owner=nullptr) | |
| Constructor. | |
| const UStringList & | additionalServerNames () const |
| For a client connection, get all addition host names for the server's certificate verification during connect(). | |
| void | addVerifyServer (const UString &name) |
| For a client connection, add another accepted host name for the server's certificate verification during connect(). | |
| virtual void | cancelSendReceive (bool silent=false) override |
| Cancel any pending send or receive operation on this socket. | |
| void | deactivateQueuedOperations (bool silent) |
| Deactivate the execution of processQueuedOperations() in the context of a Reactor handler. | |
| bool | isOpen () const |
| Check if the reactive socket is open. | |
| bool | isOwned () |
| Check if the object is owned. | |
| template<class OBJECT > requires std::derived_from<OBJECT, ts::Object> | |
| bool | isOwned () |
| Check if the object is owned by an object of a given type. | |
| Object * | owner () |
| Get the address of the optional "owner" object which was specified in the constructor. | |
| template<class OBJECT > requires std::derived_from<OBJECT, ts::Object> | |
| OBJECT * | owner () |
| Get the address of the "owner" object which was specified in the constructor. | |
| Reactor & | reactor () |
| Get a reference to the associated reactor. | |
| Report & | report () |
| Get a reference to the associated report. | |
| const UString & | serverName () const |
| For a client connection, get the server name to be used in SNI (Server Name Indication). | |
| void | setArgs (const TLSArgs &args) |
| Set command line arguments for the client. | |
| void | setServerName (const UString &server_name) |
| For a client connection, specify the server name to be used in SNI (Server Name Indication). | |
| void | setVerifyPeer (bool on) |
| Define if the peer's certificate shall be verified. | |
| bool | signalQueuedOperations () |
| Trigger the execution of processQueuedOperations() in the context of a Reactor handler. | |
| TCPConnection & | socket () |
| Get a reference to the associated socket. | |
| virtual bool | startClose (ReactiveTCPConnectionHandlerInterface *handler, bool silent=false, const ObjectPtr &user_data=ObjectPtr()) override |
| Start closing the socket. | |
| virtual bool | startCloseWriter (ReactiveTCPConnectionHandlerInterface *handler, bool silent=false, const ObjectPtr &user_data=ObjectPtr()) override |
| Start closing the send direction of the socket. | |
| virtual bool | startConnect (ReactiveTCPConnectionHandlerInterface *handler, const IPSocketAddress &addr, const ObjectPtr &user_data=ObjectPtr()) override |
| Start the operation of connecting to a TCP server. | |
| virtual bool | startReceive (ReactiveTCPConnectionHandlerInterface *handler, size_t buffer_size=DEFAULT_RECEIVE_BUFFER_SIZE, const ObjectPtr &user_data=ObjectPtr()) override |
| Start the operation of receiving messages from the socket. | |
| virtual bool | startSend (ReactiveTCPConnectionHandlerInterface *handler, const void *data, size_t size, const ObjectPtr &user_data=ObjectPtr()) override |
| Start the operation of sending data over the TCP connection. | |
| bool | verifyPeer () const |
| Check if the peer's certificate shall be verified. | |
| virtual void | whenAccepted (ReactiveTCPConnectionHandlerInterface *handler, const ObjectPtr &user_data=ObjectPtr()) override |
| Define the handler to call when accepted as a client session by a TCP server. | |
Static Public Attributes | |
| static constexpr size_t | DEFAULT_RECEIVE_BUFFER_SIZE = 4096 |
| Default buffer size for receive operations. | |
Protected Types | |
| using | HandlerType = ReactiveTCPConnectionHandlerInterface |
| Internal shorter name for handler interface. | |
| using | IOQueue = std::list< std::shared_ptr< IOSB > > |
| Queues of I/O requests are queues of shared_ptr to IOSB. | |
| using | IOSB = NonBlockingDevice::IOSB |
| IOSB shortcut fpr subclasses. | |
| using | IOSet = std::set< std::shared_ptr< IOSB > > |
| Unordered set of I/O requests, set of shared_ptr to IOSB. | |
Protected Member Functions | |
| bool | activateAsynchronousIO () |
| Activate notification for asynchronous I/O. | |
| bool | activateReadReady () |
| Activate read-ready notification for non-blocking I/O. | |
| bool | activateWriteReady () |
| Activate write-ready notification for non-blocking I/O. | |
| bool | cancelAndWaitAsynchronousIO (NonBlockingDevice::IOSB &iosb, bool silent) |
| Cancel one specific pending asynchronous I/O and wait for its completion. | |
| void | cancelAsynchronousIO (bool silent) |
| Cancel all asynchronous I/O in progress. | |
| template<class REQUEST > requires std::derived_from<REQUEST, ts::Object> | |
| void | cancelQueue (IOQueue &inqueue, IOQueue &outqueue) |
| Transfer all requests from one queue to another and mark all I/O as canceled. | |
| void | deactivateAll (bool silent) |
| Deactivate all registrations for non-blocking and asynchronous I/O. | |
| void | deactivateAsynchronousIO (bool silent) |
| Deactivate notification for asynchronous I/O. | |
| void | deactivateReadReady (bool silent) |
| Deactivate read-ready notification for non-blocking I/O. | |
| void | deactivateWriteReady (bool silent) |
| Deactivate write-ready notification for non-blocking I/O. | |
| virtual void | handleTimer (Reactor &reactor, EventId id) |
| Handle a timer in a Reactor. | |
| virtual void | handleUserEvent (Reactor &, EventId) override |
| Handle a user-defined event in a Reactor. | |
| void | processReceiveBuffer (ByteBlock &data, ReactiveTCPInputControl &control, HandlerType *handler, int error_code, const ObjectPtr &user_data) |
| Invoke the receive handler as many times as possible on a data buffer. | |
| std::shared_ptr< IOSB > | removeFromQueue (IOQueue &queue, IOSB *iosb) |
| Search and remove a shared_ptr to IOSB, based on an IOSB address. | |
SSL/TLS connected socket for use in a Reactor environment.
The class ReactiveTLSConnection is a wrapper around TCPConnection to handle reactive I/O.
The actual socket is a separate object. It is initialized and configured by the application. The application shall not directly call connect(), send(), receive(), closeWriter(), or close() on this socket and delegate these operations to startConnect(), startSend(), startReceive(), startCloseWriter() and startClose() in class ReactiveTLSConnection.
|
protectedinherited |
Queues of I/O requests are queues of shared_ptr to IOSB.
This is typically used with non-blocking I/O where we must process requests in order. Send and receive requests are structures which are stored in the react_data of the IOSB.
|
protectedinherited |
Unordered set of I/O requests, set of shared_ptr to IOSB.
This is typically used with asynchronous I/O. The ordering is enforced because I/O are started in order of calls from applications. The completion processing is likely the same, but driven by the system I/O Completion Ports and we must not assume any order. Send and receive requests are structures which are stored in the react_data of the IOSB.
| ts::ReactiveTLSConnection::ReactiveTLSConnection | ( | Reactor & | reactor, |
| TCPConnection & | socket, | ||
| Object * | owner = nullptr |
||
| ) |
Constructor.
| [in,out] | reactor | Associated reactor. The reactor object must remain valid as long as this object is valid. |
| [in,out] | socket | Associated socket. The socket object must remain valid as long as this object is valid. The ReactiveTLSConnection must be initialized before the socket is opened. Important: socket must be an instance of TCPConnection, not an instance of TLSConnection. |
| [in] | owner | Optional address of an "owner" object, typically an instance of class containing this object. |
| ts::ReactiveTLSConnection::ReactiveTLSConnection | ( | Reactor & | reactor, |
| TCPConnection & | socket, | ||
| const TLSArgs & | args, | ||
| Object * | owner = nullptr |
||
| ) |
Constructor with initial client arguments.
| [in,out] | reactor | Associated reactor. The reactor object must remain valid as long as this object is valid. |
| [in,out] | socket | Associated socket. The socket object must remain valid as long as this object is valid. The ReactiveTLSConnection must be initialized before the socket is opened. Important: socket must be an instance of TCPConnection, not an instance of TLSConnection. |
| [in] | args | Initial TLS client arguments. |
| [in] | owner | Optional address of an "owner" object, typically an instance of class containing this object. |
|
overridevirtual |
Start the operation of connecting to a TCP server.
| [in] | handler | Handler class to call when the connect operation completes. The method handleTCPConnected() will be called. If nullptr, no handler is called. |
| [in] | addr | IP address and port of the server to connect to. |
| [in] | user_data | A shared pointer which will be passed unmodified to handler. |
Reimplemented from ts::ReactiveTCPConnection.
|
overridevirtual |
Define the handler to call when accepted as a client session by a TCP server.
Typically called from the constructor of an enclosing object which is used as client session context.
| [in] | handler | Handler class to call when this object is connected to a remote client by a server. The method handleTCPAccepted() will be called. If nullptr, no handler is called. |
| [in] | user_data | A shared pointer which will be passed unmodified to handler. |
Reimplemented from ts::ReactiveTCPConnection.
|
overridevirtual |
Start the operation of sending data over the TCP connection.
| [in] | handler | Handler class to call when the send operation completes. The method handleTCPSend() will be called. If nullptr, no handler is called. |
| [in] | data | Address of the data to send. The corresponding memory area must remain valid until the completion or cancelation of the send operation. |
| [in] | size | Size in bytes of the data to send. |
| [in] | user_data | A shared pointer which will be passed unmodified to handler. |
Reimplemented from ts::ReactiveTCPConnection.
|
overridevirtual |
Start closing the send direction of the socket.
The peer will receive an end-of-file condition. All pending send operations are guaranteed to complete before that end-of-file is sent.
| [in] | handler | Handler class to call when the close-writer operation completes. The method handleTCPSend() will be called with its parameter error_code containing SYS_EOF. If nullptr, no handler is called. |
| [in] | silent | If true, do not report errors through the logger. |
| [in] | user_data | A shared pointer which will be passed unmodified to handler. |
Reimplemented from ts::ReactiveTCPConnection.
|
overridevirtual |
Start the operation of receiving messages from the socket.
| [in] | handler | Handler class to call each time data are received. The method handleTCPReceive() will be called for each new message. Cannot be null. If a previous receive handler was registered, it is replaced. |
| [in] | buffer_size | Size of input buffers to receive data. |
| [in] | user_data | A shared pointer which will be passed unmodified to handler. |
Reimplemented from ts::ReactiveTCPConnection.
|
overridevirtual |
Cancel any pending send or receive operation on this socket.
If a repeated reception operation is in progress, the repetition is canceled as well.
| [in] | silent | If true, do not report errors through the logger. |
Reimplemented from ts::ReactiveTCPConnection.
|
overridevirtual |
Start closing the socket.
Pending asynchronous operations are canceled. The actual cancelation will take place later. In the meantime, the user's data buffers for these pending operations are busy and shall not be destroyed / deallocated by the application. The close operation terminates when the handler handleTCPClosed() is invoked. At this point, no more operation is pending and the application may get rid of data buffers.
Note that the application, usually inside a handler, can call disconnect() on the TCPConnection object. Only closeWriter() and close() shall not be called and replaced by startCloseWriter() and startClose() on the ReactiveTCPConnection object.
| [in] | handler | Handler class to call when the close operation completes. The method handleTCPClosed() will be called. If nullptr, no handler is called. |
| [in] | silent | If true, do not report errors through the logger. |
| [in] | user_data | A shared pointer which will be passed unmodified to handler. |
Reimplemented from ts::ReactiveTCPConnection.
|
inlineinherited |
Get a reference to the associated socket.
|
inlineinherited |
Check if the reactive socket is open.
This is different from Socket::isOpen() during the closing phase, after startClose() has been called but before the underlying socket is fully closed.
|
protectedinherited |
Invoke the receive handler as many times as possible on a data buffer.
| [in,out] | data | Data buffer containing the received data. On output, data which are processed by the handler are removed. |
| [in,out] | control | Input control. On input, this is the previously returned value from the handler. Modified by the handler. |
| [in] | handler | Application handler. |
| [in] | error_code | Receive error code. If not success, the handler is called exactly once. |
| [in] | user_data | User data for the handler. |
|
protectedinherited |
Search and remove a shared_ptr to IOSB, based on an IOSB address.
Search from the front (end) of the queue since a completed I/O is likely on the front.
| [in,out] | queue | The queue from which to remove iosb. |
| [in] | iosb | Standard pointer to an IOSB to search and remove. |
|
protectedinherited |
Transfer all requests from one queue to another and mark all I/O as canceled.
| REQUEST | The subclass of Object which is set in react_data of all requests in inqueue. |
| [in,out] | inqueue | The queue from which all requests are removed. |
| [in,out] | outqueue | The queue which receives all canceled requests. |
|
protectedinherited |
Activate read-ready notification for non-blocking I/O.
|
protectedinherited |
Deactivate read-ready notification for non-blocking I/O.
| [in] | silent | If true, do not report errors through the logger. |
|
protectedinherited |
Activate write-ready notification for non-blocking I/O.
|
protectedinherited |
Deactivate write-ready notification for non-blocking I/O.
| [in] | silent | If true, do not report errors through the logger. |
|
protectedinherited |
Activate notification for asynchronous I/O.
|
protectedinherited |
Deactivate notification for asynchronous I/O.
| [in] | silent | If true, do not report errors through the logger. |
|
protectedinherited |
Cancel all asynchronous I/O in progress.
The cancelation occurs in the background and end of canceled asynchronous I/O will be notified.
| [in] | silent | If true, do not report errors through the logger. |
|
protectedinherited |
Cancel one specific pending asynchronous I/O and wait for its completion.
Warning: This is a blocking call. It shall be used in case of trouble only.
| [in,out] | iosb | The asynchronous I/O status block. |
| [in] | silent | If true, do not report errors through the logger. |
|
protectedinherited |
Deactivate all registrations for non-blocking and asynchronous I/O.
| [in] | silent | If true, do not report errors through the logger. |
|
inlineinherited |
Get a reference to the associated reactor.
|
inlineinherited |
Get a reference to the associated report.
|
inherited |
Trigger the execution of processQueuedOperations() in the context of a Reactor handler.
Create if necessary and then signal a dedicated user event.
|
inherited |
Deactivate the execution of processQueuedOperations() in the context of a Reactor handler.
Deactivate and delete the dedicated user event.
| [in] | silent | If true, do not report errors through the logger. |
|
overrideprotectedvirtualinherited |
Handle a user-defined event in a Reactor.
| [in,out] | reactor | Reactor into which the handler is invoked. |
| [in] | id | Id of the event which was signaled. |
Reimplemented from ts::ReactorHandlerInterface.
|
inlineinherited |
Get the address of the optional "owner" object which was specified in the constructor.
|
inherited |
Get the address of the "owner" object which was specified in the constructor.
This template version requires that the owner objet is set and of type OBJECT, or some subclass of it. If there is no owner object or if it is not compatible with the template class OBJECT, this is a fatal error and the application is terminated.
| OBJECT | A subclass of Object |
|
inlineinherited |
Check if the object is owned.
|
inlineinherited |
Check if the object is owned by an object of a given type.
| OBJECT | A subclass of Object |
|
inherited |
Set command line arguments for the client.
| [in] | args | TLS arguments. |
|
inlineinherited |
Define if the peer's certificate shall be verified.
| [in] | on | If true, the peer's certificate will be verified. |
|
inlineinherited |
Check if the peer's certificate shall be verified.
|
inherited |
For a client connection, specify the server name to be used in SNI (Server Name Indication).
| [in] | server_name | Main server name, as specified in SNI (Server Name Indication). Also used to verify the server's certificate when setVerifyPeer() is true. |
|
inlineinherited |
For a client connection, get the server name to be used in SNI (Server Name Indication).
|
inherited |
For a client connection, add another accepted host name for the server's certificate verification during connect().
The list is reset by setServerName().
| [in] | name | Additional accepted host name used to verify the server's certificate. |
|
inlineinherited |
For a client connection, get all addition host names for the server's certificate verification during connect().
|
staticconstexprinherited |
Default buffer size for receive operations.