blob: e7837afcefea229dffe008b3dad57dd358d7eadb (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
|
// Copyright (C) 2018 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
#include "qwebengineclientcertificatestore.h"
#include "net/client_cert_store_data.h"
#include <QList>
QT_BEGIN_NAMESPACE
#if QT_CONFIG(ssl)
/*!
\class QWebEngineClientCertificateStore
\inmodule QtWebEngineCore
\since 5.13
\brief The QWebEngineClientCertificateStore class provides an in-memory store for client certificates.
The class allows to store client certificates in an in-memory store.
When a web site requests an SSL client certificate, the QWebEnginePage::selectClientCertificate
signal is emitted with matching certificates from the native certificate store or the in-memory store.
The getInstance() method can be used to access the single instance of the class.
*/
QWebEngineClientCertificateStore::QWebEngineClientCertificateStore(QtWebEngineCore::ClientCertificateStoreData *storeData)
: m_storeData(storeData)
{}
/*!
Destroys this QWebEngineClientCertificateStore object.
*/
QWebEngineClientCertificateStore::~QWebEngineClientCertificateStore()
{
// Just in case user has not deleted in-memory certificates
clear();
}
/*!
Adds a \a certificate with the \a privateKey to the in-memory client certificate store.
*/
void QWebEngineClientCertificateStore::add(const QSslCertificate &certificate, const QSslKey &privateKey)
{
m_storeData->add(certificate, privateKey);
}
/*!
Returns a list of the client certificates in the in-memory store.
Returns an empty list if the store does not contain any certificates.
*/
QList<QSslCertificate> QWebEngineClientCertificateStore::certificates() const
{
QList<QSslCertificate> certificateList;
for (auto data : qAsConst(m_storeData->extraCerts))
certificateList.append(data->certificate);
return certificateList;
}
/*!
Deletes all the instances of the client certificate in the in-memory client certificate store
that matches the certificate \a certificate.
*/
void QWebEngineClientCertificateStore::remove(const QSslCertificate &certificate)
{
m_storeData->remove(certificate);
}
/*!
Clears all the client certificates from the in-memory store.
*/
void QWebEngineClientCertificateStore::clear()
{
m_storeData->clear();
}
#endif // QT_CONFIG(ssl)
QT_END_NAMESPACE
|