1/****************************************************************************
2**
3** Copyright (C) 2014 Digia Plc and/or its subsidiary(-ies).
4** Contact: http://www.qt-project.org/legal
5**
6** This file is part of the QtNetwork module of the Qt Toolkit.
7**
8** $QT_BEGIN_LICENSE:LGPL$
9** Commercial License Usage
10** Licensees holding valid commercial Qt licenses may use this file in
11** accordance with the commercial license agreement provided with the
12** Software or, alternatively, in accordance with the terms contained in
13** a written agreement between you and Digia. For licensing terms and
14** conditions see http://qt.digia.com/licensing. For further information
15** use the contact form at http://qt.digia.com/contact-us.
16**
17** GNU Lesser General Public License Usage
18** Alternatively, this file may be used under the terms of the GNU Lesser
19** General Public License version 2.1 as published by the Free Software
20** Foundation and appearing in the file LICENSE.LGPL included in the
21** packaging of this file. Please review the following information to
22** ensure the GNU Lesser General Public License version 2.1 requirements
23** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
24**
25** In addition, as a special exception, Digia gives you certain additional
26** rights. These rights are described in the Digia Qt LGPL Exception
27** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
28**
29** GNU General Public License Usage
30** Alternatively, this file may be used under the terms of the GNU
31** General Public License version 3.0 as published by the Free Software
32** Foundation and appearing in the file LICENSE.GPL included in the
33** packaging of this file. Please review the following information to
34** ensure the GNU General Public License version 3.0 requirements will be
35** met: http://www.gnu.org/copyleft/gpl.html.
36**
37**
38** $QT_END_LICENSE$
39**
40****************************************************************************/
41
42
43#ifndef QSSLCERTIFICATE_H
44#define QSSLCERTIFICATE_H
45
46#include <QtCore/qnamespace.h>
47#include <QtCore/qbytearray.h>
48#include <QtCore/qcryptographichash.h>
49#include <QtCore/qregexp.h>
50#include <QtCore/qsharedpointer.h>
51#include <QtNetwork/qssl.h>
52
53typedef struct x509_st X509; // ### check if this works
54
55QT_BEGIN_HEADER
56
57QT_BEGIN_NAMESPACE
58
59QT_MODULE(Network)
60
61#ifndef QT_NO_OPENSSL
62
63class QDateTime;
64class QIODevice;
65class QSslKey;
66class QStringList;
67template <typename T, typename U> class QMultiMap;
68
69class QSslCertificatePrivate;
70class Q_NETWORK_EXPORT QSslCertificate
71{
72public:
73 enum SubjectInfo {
74 Organization,
75 CommonName,
76 LocalityName,
77 OrganizationalUnitName,
78 CountryName,
79 StateOrProvinceName
80 };
81
82 QSslCertificate(QIODevice *device, QSsl::EncodingFormat format = QSsl::Pem);
83 QSslCertificate( // ### s/encoded/data (to be consistent with signature in .cpp file) ?
84 const QByteArray &encoded = QByteArray(), QSsl::EncodingFormat format = QSsl::Pem);
85 QSslCertificate(const QSslCertificate &other);
86 ~QSslCertificate();
87 QSslCertificate &operator=(const QSslCertificate &other);
88 bool operator==(const QSslCertificate &other) const;
89 inline bool operator!=(const QSslCertificate &other) const { return !operator==(other); }
90
91 bool isNull() const;
92 bool isValid() const;
93 void clear();
94
95 // Certificate info
96 QByteArray version() const;
97 QByteArray serialNumber() const;
98 QByteArray digest(QCryptographicHash::Algorithm algorithm = QCryptographicHash::Md5) const;
99 QString issuerInfo(SubjectInfo info) const;
100 QString issuerInfo(const QByteArray &tag) const;
101 QString subjectInfo(SubjectInfo info) const;
102 QString subjectInfo(const QByteArray &tag) const;
103 QMultiMap<QSsl::AlternateNameEntryType, QString> alternateSubjectNames() const;
104 QDateTime effectiveDate() const;
105 QDateTime expiryDate() const;
106 QSslKey publicKey() const;
107
108 QByteArray toPem() const;
109 QByteArray toDer() const;
110
111 static QList<QSslCertificate> fromPath(
112 const QString &path, QSsl::EncodingFormat format = QSsl::Pem,
113 QRegExp::PatternSyntax syntax = QRegExp::FixedString);
114 static QList<QSslCertificate> fromDevice(
115 QIODevice *device, QSsl::EncodingFormat format = QSsl::Pem);
116 static QList<QSslCertificate> fromData(
117 const QByteArray &data, QSsl::EncodingFormat format = QSsl::Pem);
118
119 Qt::HANDLE handle() const;
120
121private:
122 QExplicitlySharedDataPointer<QSslCertificatePrivate> d;
123 friend class QSslCertificatePrivate;
124 friend class QSslSocketBackendPrivate;
125};
126
127#ifndef QT_NO_DEBUG_STREAM
128class QDebug;
129Q_NETWORK_EXPORT QDebug operator<<(QDebug debug, const QSslCertificate &certificate);
130Q_NETWORK_EXPORT QDebug operator<<(QDebug debug, QSslCertificate::SubjectInfo info);
131#endif
132
133#endif // QT_NO_OPENSSL
134
135QT_END_NAMESPACE
136
137QT_END_HEADER
138
139#endif
140