1// Copyright (C) 2021 The Qt Company Ltd.
2// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
3// Qt-Security score:significant reason:default
4
5#ifndef QDTLS_BASE_P_H
6#define QDTLS_BASE_P_H
7
8//
9// W A R N I N G
10// -------------
11//
12// This file is not part of the Qt API. It exists purely as an
13// implementation detail. This header file may change from version to
14// version without notice, or even be removed.
15//
16// We mean it.
17//
18
19#include <QtNetwork/private/qtnetworkglobal_p.h>
20
21QT_REQUIRE_CONFIG(dtls);
22
23#include <QtNetwork/private/qtlsbackend_p.h>
24
25#include <QtNetwork/qsslconfiguration.h>
26#include <QtNetwork/qsslcipher.h>
27#include <QtNetwork/qsslsocket.h>
28#include <QtNetwork/qssl.h>
29
30#include <QtNetwork/qhostaddress.h>
31
32#include <QtCore/qcryptographichash.h>
33#include <QtCore/qbytearray.h>
34#include <QtCore/qglobal.h>
35#include <QtCore/qstring.h>
36
37QT_BEGIN_NAMESPACE
38
39// This class exists to re-implement the shared error/cookie handling
40// for both QDtls and QDtlsClientVerifier classes. Use it if/when
41// you need it. Backend neutral.
42class QDtlsBasePrivate : virtual public QTlsPrivate::DtlsBase
43{
44public:
45 QDtlsBasePrivate(QSslSocket::SslMode m, const QByteArray &s) : mode(m), secret(s) {}
46 void setDtlsError(QDtlsError code, const QString &description) override;
47 QDtlsError error() const override;
48 QString errorString() const override;
49 void clearDtlsError() override;
50
51 void setConfiguration(const QSslConfiguration &configuration) override;
52 QSslConfiguration configuration() const override;
53
54 bool setCookieGeneratorParameters(const GenParams &) override;
55 GenParams cookieGeneratorParameters() const override;
56
57 static bool isDtlsProtocol(QSsl::SslProtocol protocol);
58
59 QHostAddress remoteAddress;
60 quint16 remotePort = 0;
61 quint16 mtuHint = 0;
62
63 QDtlsError errorCode = QDtlsError::NoError;
64 QString errorDescription;
65 QSslConfiguration dtlsConfiguration;
66 QSslSocket::SslMode mode = QSslSocket::SslClientMode;
67 QSslCipher sessionCipher;
68 QSsl::SslProtocol sessionProtocol = QSsl::UnknownProtocol;
69 QString peerVfyName;
70 QByteArray secret;
71
72 QCryptographicHash::Algorithm hashAlgorithm = QCryptographicHash::Sha256;
73};
74
75QT_END_NAMESPACE
76
77#endif // QDTLS_BASE_P_H
78

source code of qtbase/src/plugins/tls/shared/qdtls_base_p.h