![]() |
TSDuck v3.44-4659
MPEG Transport Stream Toolkit
|
Implementation of a SSL/TLS server. More...
#include <tsTLSServer.h>


Public Types | |
| using | SuperClass = TCPServer |
| Reference to the superclass. | |
Public Member Functions | |
| TLSServer (Report *report, const TLSArgs &args) | |
| Constructor with initial arguments. | |
| TLSServer (Report *report=nullptr) | |
| Constructor. | |
| TLSServer (ReporterBase *delegate) | |
| Constructor. | |
| TLSServer (ReporterBase *delegate, const TLSArgs &args) | |
| Constructor with initial arguments. | |
| virtual bool | accept (TCPConnection &client, IPSocketAddress &addr, IOSB *=nullptr) override |
| Wait for an incoming client connection. | |
| void | addSubscription (SocketHandlerInterface *handler) |
| Add a subscriber to open/close events. | |
| bool | bind (const IPSocketAddress &addr) |
| Bind to a local address and port. | |
| void | cancelSubscription (SocketHandlerInterface *handler) |
| Remove a subscriber to open/close events. | |
| virtual bool | close (bool silent=false) override |
| Close the socket. | |
| IP | generation () const |
| Get the IP generation with which the socket was open. | |
| const UString & | getCertificatePath () const |
| Get the certificate path for the server. | |
| const UString & | getCertificateStore () const |
| Get the certificate store. | |
| const UString & | getKeyPath () const |
| Get the private key path for the server. | |
| bool | getLocalAddress (IPSocketAddress &addr) const |
| Get local socket address. | |
| SysSocketType | getSocket () const |
| Get the underlying socket device handle (use with care). | |
| bool | isNonBlocking () const |
| Check if the device is in non-blocking mode. | |
| bool | isOpen () const |
| Check if socket is open. | |
| virtual bool | listen (int backlog) override |
| Start the server. | |
| bool | muteReport (bool mute) |
| Temporarily mute the associated report. | |
| virtual bool | open (IP gen) override |
| Open the socket. | |
| Report & | report () const |
| Access the Report which is associated with this object. | |
| bool | reusePort (bool reuse_port) |
| Set the "reuse port" option. | |
| void | setArgs (const TLSArgs &args) |
| Set command line arguments for the server. | |
| void | setCertificatePath (const UString &path) |
| Set the certificate path for the server. | |
| void | setCertificateStore (const UString &name) |
| Set the certificate store. | |
| bool | setKeepAlive (bool active) |
| Set the "keep alive" option. | |
| void | setKeyPath (const UString &path) |
| Set the private key path for the server. | |
| bool | setLingerTime (int seconds) |
| Set the linger time option. | |
| bool | setNoDelay (bool active) |
| Set the "no delay" option. | |
| bool | setNoLinger () |
| Remove the linger time option. | |
| bool | setNonBlocking (bool non_blocking) |
| Set the device in non-blocking mode. | |
| bool | setReceiveBufferSize (size_t size) |
| Set the receive buffer size. | |
| bool | setReceiveTimeout (cn::milliseconds timeout) |
| Set the receive timeout. | |
| Report * | setReport (Report *report) |
| Associate this object with another Report to log errors. | |
| ReporterBase * | setReport (ReporterBase *delegate) |
| Associate this object with another ReporterBase to log errors. | |
| bool | setSendBufferSize (size_t size) |
| Set the send buffer size. | |
| bool | setTTL (int ttl) |
| Set the Time To Live (TTL) option. | |
Static Public Member Functions | |
| static int | SilentLevel (bool silent) |
| Compute a log severity level from a "silent" parameter. | |
Protected Member Functions | |
| virtual bool | allowSetNonBlocking () const override |
| Check that the non-blocking mode can be set. | |
| bool | checkNonBlocking (bool non_blocking, const UChar *opname) |
| Check the blocking mode of a device. | |
| bool | checkNonBlocking (IOSB *iosb, const UChar *opname) |
| Check the blocking mode of a device. | |
| bool | convert (IPAddress &addr) const |
| Convert an IP address to make it compatible with the socket IP generation. | |
| bool | createSocket (IP gen, int type, int protocol) |
| Create the socket. | |
| virtual void | declareOpened (SysSocketType sock) override |
| Set an open socket descriptor from a subclass. | |
| virtual void | handleClosed () |
| This virtual method can be overriden by subclasses to be notified of close. | |
| virtual void | handleOpened () |
| This virtual method can be overriden by subclasses to be notified of open. | |
| bool | setSystemNonBlocking (SysSocketType fd, bool non_blocking) |
| Convenience method to set a system file descriptor or socket handle in non-blocking mode. | |
Protected Attributes | |
| std::recursive_mutex | _mutex {} |
| Mutex protecting this object. | |
Implementation of a SSL/TLS server.
On UNIX systems (with OpenSSL):
To display the properties of the certificate:
On Windows:
To display the properties of the certificate:
A self-signed certificate is considered as invalid. So, make sure to ignore this error. With curl, use option –insecure or -k.
To view the certificate of a server using OpenSSL:
|
explicit |
Constructor.
| [in] | report | Where to report errors. The report object must remain valid as long as this object exists or setReport() is used with another Report object. If report is null, log messages are discarded. |
|
explicit |
Constructor.
| [in] | delegate | Use the report of another ReporterBase. If delegate is null, log messages are discarded. |
Constructor with initial arguments.
| [in] | report | Where to report errors. The report object must remain valid as long as this object exists or setReport() is used with another Report object. If report is null, log messages are discarded. |
| [in] | args | Initial TLS arguments. |
|
inline |
Constructor with initial arguments.
| [in] | delegate | Use the report of another ReporterBase. If delegate is null, log messages are discarded. |
| [in] | args | Initial TLS arguments. |
| void ts::TLSServer::setArgs | ( | const TLSArgs & | args | ) |
Set command line arguments for the server.
| [in] | args | TLS arguments. |
|
inline |
Set the certificate path for the server.
| [in] | path | Path to the certificate.
|
|
inline |
Get the certificate path for the server.
|
inline |
Set the private key path for the server.
| [in] | path | Path to the private key.
|
|
inline |
Get the private key path for the server.
|
inline |
Set the certificate store.
| [in] | name |
|
|
inline |
Get the certificate store.
|
overridevirtual |
Start the server.
Here, starting the server means starting to listen to incoming client connections. Internally to the kernel, the incoming connections are queued up to backlog. When the method accept() is invoked and some incoming connections are already queued in the kernel, the oldest one is immediately accepted. Otherwise, accept() blocks until a new incoming connection arrives.
| [in] | backlog | Maximum number of incoming connections which allowed to queue in the kernel until the next call to accept(). Note that this value is a minimum queue size. But the kernel may accept more. There is no guarantee that additional incoming connections will be rejected if more than backlog are already queueing. |
Reimplemented from ts::TCPServer.
|
overridevirtual |
Wait for an incoming client connection.
| [out] | client | This object receives the new connection. Upon successful return from accept(), the TCPConnection object is a properly connected TCP session. Once the connection is completed, the TCPConnection objects on the client side and the server side are symmetric and can be used the same way. |
| [out] | addr | This object receives the socket address of the client. If the server wants to filter client connections based on their IP address, it may use addr for that. |
| [in,out] | iosb | Address of an IOSB structure. If non-null, the socket must be in non-blocking mode. When null, the socket must be in blocking mode (the default). See the description of IOSB. Important: The parameter iosb should not be used by applications. It should be used only by "reactive classes", which work in combination with a Reactor. |
Reimplemented from ts::TCPServer.
|
overridevirtual |
Close the socket.
If overridden by a subclass, the superclass must be called at the end of the overridden close().
| [in] | silent | If true, do not report errors through the logger. This is typically useful when the socket is in some error condition and closing it is necessary although it may generate additional meaningless errors. |
Reimplemented from ts::TCPServer.
|
inherited |
Set the Time To Live (TTL) option.
| [in] | ttl | The TTL value, ie. the maximum number of "hops" between routers before an IP packet is dropped. |
|
inherited |
Remove the linger time option.
|
inherited |
Set the linger time option.
| [in] | seconds | Number of seconds to wait after shuting down the socket. |
|
inherited |
Set the "keep alive" option.
| [in] | active | If true, the socket periodically sends "keep alive" packets when the connection is idle. |
|
inherited |
Set the "no delay" option.
| [in] | active | If true, the socket immediately sends outgoing packets. By default, a TCP socket waits a small amount of time after a send() operation to get a chance to group outgoing data from successive send() operations into one single packet. |
|
overridevirtualinherited |
Open the socket.
| [in] | gen | IP generation, IPv4 or IPv6. If set to IP::Any, open an IPv6 socket (IPv4 connections allowed). |
Implements ts::Socket.
|
protectedvirtualinherited |
This virtual method can be overriden by subclasses to be notified of open.
All subclasses should explicitly invoke their superclass' handlers.
|
protectedvirtualinherited |
This virtual method can be overriden by subclasses to be notified of close.
All subclasses should explicitly invoke their superclass' handlers.
Reimplemented in ts::TCPConnection.
|
overrideprotectedvirtualinherited |
Set an open socket descriptor from a subclass.
This method is used by a server to declare that a client socket has just become opened.
| [in] | sock | New socket descriptor. |
Reimplemented from ts::Socket.
|
inlineinherited |
Check if socket is open.
|
inlineinherited |
Get the IP generation with which the socket was open.
|
inherited |
Set the send buffer size.
| [in] | size | Send buffer size in bytes. |
|
inherited |
Set the receive buffer size.
| [in] | size | Receive buffer size in bytes. |
|
inherited |
Set the receive timeout.
| [in] | timeout | Receive timeout in milliseconds. If negative or zero, receive timeout is not used, reception waits forever. |
|
inherited |
Set the "reuse port" option.
| [in] | reuse_port | If true, the socket is allowed to reuse a local UDP port which is already bound. |
|
inherited |
Bind to a local address and port.
The IP address part of the socket address must one of:
Special note for receiving multicast on most Unix systems (at least Linux and macOS): The IP address shall be either AnyAddress4 or the multicast group address. Do not specify a local address to receive multicast on Unix.
The port number part of the socket address must be one of:
| [in] | addr | Local socket address to bind to. |
|
inherited |
Get local socket address.
| [out] | addr | Local socket address of the connection. |
|
inlineinherited |
Get the underlying socket device handle (use with care).
This method is reserved for low-level operations and should not be used by normal applications.
|
inherited |
|
inherited |
|
protectedinherited |
|
protectedinherited |
Convert an IP address to make it compatible with the socket IP generation.
| addr | [in,out] The address to convert. |
|
overrideprotectedvirtualinherited |
Check that the non-blocking mode can be set.
Must be implemented by subclasses which do not support setting the non-blocking in certain states, such as after being opened. The default implementation always allows setting the non-blocking mode.
Reimplemented from ts::NonBlockingDevice.
|
inherited |
Set the device in non-blocking mode.
Important: Usually, this method must be called before opening the device, whatever it means. Otherwise it is ignored and the device blocking mode is unchanged.
| [in] | non_blocking | It true, the device is set in non-blocking mode. |
|
inlineinherited |
Check if the device is in non-blocking mode.
|
protectedinherited |
Check the blocking mode of a device.
Called by subclass methods which are explicitly called in blocking or non-blocking mode.
| [in] | non_blocking | The required non-blocking mode. |
| [in] | opname | Name of the operation, for the error message. |
|
protectedinherited |
Check the blocking mode of a device.
Called by subclass methods which are explicitly called in blocking or non-blocking mode.
| [in,out] | iosb | Address of an IOSB structure. If non-null, we are in non-blocking mode. When null, we are in blocking mode. When non-null, pending is reset to false and overlap is zeroed. |
| [in] | opname | Name of the operation, for the error message. |
|
protectedinherited |
Convenience method to set a system file descriptor or socket handle in non-blocking mode.
| [in] | fd | System file descriptor (UNIX) or socket handle (Windows). On Windows, non-socket devices shall be opened with flag FILE_FLAG_OVERLAPPED instead of using this method. |
| [in] | non_blocking | It true, the device is set in non-blocking mode. |
|
inherited |
Associate this object with another Report to log errors.
| [in] | report | Where to report errors. The report object must remain valid as long as this object exists or setReport() is used with another Report object. If report is null, log messages are discarded. |
|
inherited |
Associate this object with another ReporterBase to log errors.
| [in] | delegate | Use the report of another ReporterBase. If delegate is null, the previous explicit Report is used.. |
|
inherited |
Temporarily mute the associated report.
| [in] | mute | It true, report() will return a null report (log messages are discarded), until muteReport() is invoked again with mute set to false. |
|
inlinestaticinherited |
Compute a log severity level from a "silent" parameter.
Some subclass methods have a "silent" parameter to avoid reporting errors which may be insignificant, typically when closing a device after an error, in which case the close operation may produce other errors if the previous error left the device in an inconsistent state. While those errors should not be displayed as errors, we still display them at debug level.
| [in] | silent | If true, do not report errors, report debug messages instead. |