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 QX509CERTIFICATE_BASE_P_H
6#define QX509CERTIFICATE_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
21#include <QtNetwork/private/qtlsbackend_p.h>
22
23#include <QtNetwork/qssl.h>
24
25#include <QtCore/qbytearray.h>
26#include <QtCore/qstring.h>
27#include <QtCore/qglobal.h>
28#include <QtCore/qlist.h>
29
30QT_BEGIN_NAMESPACE
31
32namespace QTlsPrivate {
33
34class X509CertificateBase : public X509Certificate
35{
36public:
37 bool isNull() const override;
38 QByteArray version() const override;
39 QByteArray serialNumber() const override;
40 QStringList issuerInfo(QSslCertificate::SubjectInfo info) const override;
41 QStringList issuerInfo(const QByteArray &attribute) const override;
42 QStringList subjectInfo(QSslCertificate::SubjectInfo info) const override;
43 QStringList subjectInfo(const QByteArray &attribute) const override;
44 QList<QByteArray> subjectInfoAttributes() const override;
45 QList<QByteArray> issuerInfoAttributes() const override;
46 QDateTime effectiveDate() const override;
47 QDateTime expiryDate() const override;
48
49 qsizetype numberOfExtensions() const override;
50 QString oidForExtension(qsizetype index) const override;
51 QString nameForExtension(qsizetype index) const override;
52 QVariant valueForExtension(qsizetype index) const override;
53 bool isExtensionCritical(qsizetype index) const override;
54 bool isExtensionSupported(qsizetype index) const override;
55
56 static QByteArray subjectInfoToString(QSslCertificate::SubjectInfo info);
57 static bool matchLineFeed(const QByteArray &pem, int *offset);
58
59protected:
60 bool validIndex(qsizetype index) const
61 {
62 return index >= 0 && index < extensions.size();
63 }
64
65 bool null = true;
66 QByteArray versionString;
67 QByteArray serialNumberString;
68
69 QMultiMap<QByteArray, QString> issuerInfoEntries;
70 QMultiMap<QByteArray, QString> subjectInfoEntries;
71 QDateTime notValidAfter;
72 QDateTime notValidBefore;
73
74 struct X509CertificateExtension
75 {
76 QString oid;
77 QString name;
78 QVariant value;
79 bool critical = false;
80 bool supported = false;
81 };
82
83 QList<X509CertificateExtension> extensions;
84};
85
86} // namespace QTlsPrivate
87
88QT_END_NAMESPACE
89
90#endif // QX509CERTIFICATE_BASE_P_H
91

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