![]() |
Qt
Internal/Contributor docs for the Qt SDK. Note: These are NOT official API docs; those are found at https://doc.qt.io/
|
Describes exported keying material derived from a TLS session. More...
#include <qsslkeyingmaterial.h>
Public Member Functions | |
| QSslKeyingMaterial (const QByteArray &label, qsizetype size, const QByteArray &context=QByteArray()) noexcept | |
| Constructs a QSslKeyingMaterial object with the given exporter label, output size, and optional context. | |
| bool | isValid () const noexcept |
| Returns true if this QSslKeyingMaterial object describes a valid exporter request. | |
| QByteArray | label () const noexcept |
| Returns the exporter label used for deriving the keying material. | |
| QByteArray | context () const noexcept |
| Returns the optional context value used for deriving the keying material. | |
| QByteArray | value () const noexcept |
| Returns the exported keying material. | |
| qsizetype | size () const noexcept |
| The desired size of the keying material. | |
Friends | |
| class | QTlsPrivate::TlsCryptographOpenSSL |
| bool | comparesEqual (const QSslKeyingMaterial &lhs, const QSslKeyingMaterial &rhs) noexcept |
Related Symbols | |
(Note that these are not member symbols.) | |
| QDebug | operator<< (QDebug debug, QSslKeyingMaterial keying) |
| Writes a textual representation of the keying material keying to the debug object debug. | |
Describes exported keying material derived from a TLS session.
\reentrant
\inmodule QtNetwork
QSslKeyingMaterial represents a request for keying material derived from an established TLS connection using the TLS exporter mechanism.
The exporter mechanism is defined in RFC 5705 for TLS 1.2 and earlier and in RFC 8446 for TLS 1.3. It allows applications to derive cryptographically separate keying material from the TLS session without exposing the session's traffic keys.
Each QSslKeyingMaterial object specifies: \list
The actual keying material is derived by the TLS backend after a successful handshake and can be retrieved via value().
QSslKeyingMaterial objects are typically configured via QSslConfiguration::setKeyingMaterial() before initiating a TLS connection.
Example: Deterministic export on client and server
Definition at line 18 of file qsslkeyingmaterial.h.
|
inlineexplicitnoexcept |
Constructs a QSslKeyingMaterial object with the given exporter label, output size, and optional context.
The label identifies the purpose of the exported keying material and must be non-empty. The size specifies the number of bytes to be derived from the TLS exporter.
The optional context is application-defined data that is mixed into the key derivation process to provide domain separation.
The keying material itself is not generated until a TLS handshake has completed successfully.
Definition at line 21 of file qsslkeyingmaterial.h.
References QSslKeyingMaterial().
Referenced by QSslKeyingMaterial().
|
inlinenoexcept |
Returns the optional context value used for deriving the keying material.
The context value binds the exported keying material to application-specific data and helps prevent accidental reuse of identical keys across different purposes.
If no context was specified, an empty QByteArray is returned.
Definition at line 41 of file qsslkeyingmaterial.h.
|
inlinenoexcept |
Returns true if this QSslKeyingMaterial object describes a valid exporter request.
A QSslKeyingMaterial object is considered valid if it has a non-empty exporter label and a positive output size.
Definition at line 31 of file qsslkeyingmaterial.h.
|
inlinenoexcept |
Returns the exporter label used for deriving the keying material.
The label identifies the purpose of the exported keying material and is included verbatim in the TLS exporter derivation.
Definition at line 36 of file qsslkeyingmaterial.h.
|
inlinenoexcept |
The desired size of the keying material.
The desired size is the number of bytes the handshake protocol is asked to generate for the purpose described by the \l label() and \l context() of the requested keying material.
Definition at line 51 of file qsslkeyingmaterial.h.
|
inlinenoexcept |
Returns the exported keying material.
The returned QByteArray contains the keying material derived from the TLS session using the configured exporter label and context.
If the TLS handshake has not completed successfully or if the TLS backend does not support key exporters, this function returns an empty value.
Definition at line 46 of file qsslkeyingmaterial.h.
|
friend |
Definition at line 62 of file qsslkeyingmaterial.h.
|
Writes a textual representation of the keying material keying to the debug object debug.
Definition at line 161 of file qsslkeyingmaterial.cpp.
|
friend |
Definition at line 72 of file qsslkeyingmaterial.h.