source: trunk/src/network/ssl/qsslsocket_openssl_p.h@ 1165

Last change on this file since 1165 was 846, checked in by Dmitry A. Kuminov, 14 years ago

trunk: Merged in qt 4.7.2 sources from branches/vendor/nokia/qt.

File size: 5.4 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
4** All rights reserved.
5** Contact: Nokia Corporation ([email protected])
6**
7** This file is part of the QtNetwork module of the Qt Toolkit.
8**
9** $QT_BEGIN_LICENSE:LGPL$
10** Commercial Usage
11** Licensees holding valid Qt Commercial licenses may use this file in
12** accordance with the Qt Commercial License Agreement provided with the
13** Software or, alternatively, in accordance with the terms contained in
14** a written agreement between you and Nokia.
15**
16** GNU Lesser General Public License Usage
17** Alternatively, this file may be used under the terms of the GNU Lesser
18** General Public License version 2.1 as published by the Free Software
19** Foundation and appearing in the file LICENSE.LGPL included in the
20** packaging of this file. Please review the following information to
21** ensure the GNU Lesser General Public License version 2.1 requirements
22** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
23**
24** In addition, as a special exception, Nokia gives you certain additional
25** rights. These rights are described in the Nokia Qt LGPL Exception
26** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
27**
28** GNU General Public License Usage
29** Alternatively, this file may be used under the terms of the GNU
30** General Public License version 3.0 as published by the Free Software
31** Foundation and appearing in the file LICENSE.GPL included in the
32** packaging of this file. Please review the following information to
33** ensure the GNU General Public License version 3.0 requirements will be
34** met: http://www.gnu.org/copyleft/gpl.html.
35**
36** If you have questions regarding the use of this file, please contact
37** Nokia at [email protected].
38** $QT_END_LICENSE$
39**
40****************************************************************************/
41
42
43#ifndef QSSLSOCKET_OPENSSL_P_H
44#define QSSLSOCKET_OPENSSL_P_H
45
46//
47// W A R N I N G
48// -------------
49//
50// This file is not part of the Qt API. It exists for the convenience
51// of the QLibrary class. This header file may change from
52// version to version without notice, or even be removed.
53//
54// We mean it.
55//
56
57#include "qsslsocket_p.h"
58
59#ifdef Q_OS_WIN
60#include <qt_windows.h>
61#if defined(OCSP_RESPONSE)
62#undef OCSP_RESPONSE
63#endif
64#endif
65
66#include <openssl/asn1.h>
67#include <openssl/bio.h>
68#include <openssl/bn.h>
69#include <openssl/err.h>
70#include <openssl/evp.h>
71#include <openssl/pem.h>
72#include <openssl/pkcs12.h>
73#include <openssl/pkcs7.h>
74#include <openssl/rand.h>
75#include <openssl/ssl.h>
76#include <openssl/stack.h>
77#include <openssl/x509.h>
78#include <openssl/x509v3.h>
79#include <openssl/x509_vfy.h>
80#include <openssl/dsa.h>
81#include <openssl/rsa.h>
82
83#if OPENSSL_VERSION_NUMBER >= 0x10000000L
84typedef _STACK STACK;
85#endif
86
87QT_BEGIN_NAMESPACE
88
89class QSslSocketBackendPrivate : public QSslSocketPrivate
90{
91 Q_DECLARE_PUBLIC(QSslSocket)
92public:
93 QSslSocketBackendPrivate();
94 virtual ~QSslSocketBackendPrivate();
95
96 // SSL context
97 bool initSslContext();
98 SSL *ssl;
99 SSL_CTX *ctx;
100 EVP_PKEY *pkey;
101 BIO *readBio;
102 BIO *writeBio;
103 SSL_SESSION *session;
104 X509_STORE *certificateStore;
105 X509_STORE_CTX *certificateStoreCtx;
106 QList<QPair<int, int> > errorList;
107
108 // Platform specific functions
109 void startClientEncryption();
110 void startServerEncryption();
111 void transmit();
112 bool startHandshake();
113 void disconnectFromHost();
114 void disconnected();
115 QSslCipher sessionCipher() const;
116
117 static QSslCipher QSslCipher_from_SSL_CIPHER(SSL_CIPHER *cipher);
118 static QList<QSslCertificate> STACKOFX509_to_QSslCertificates(STACK_OF(X509) *x509);
119 Q_AUTOTEST_EXPORT static bool isMatchingHostname(const QString &cn, const QString &hostname);
120 static QString getErrorsFromOpenSsl();
121};
122
123#if defined(Q_OS_SYMBIAN)
124
125#include <QByteArray>
126#include <e32base.h>
127#include <f32file.h>
128#include <unifiedcertstore.h> // link against certstore.lib
129#include <ccertattributefilter.h> // link against ctframework.lib
130
131// The purpose of this class is to wrap the asynchronous API of Symbian certificate store to one
132// synchronizable call. The user of this class needs to provide a TRequestStatus object which can
133// be used with User::WaitForRequest() unlike with the calls of the certificate store API.
134// A thread is used instead of a CActiveSchedulerWait scheme, because that would make the call
135// asynchronous (other events might be processed during the call even though the call would be seemingly
136// synchronous).
137
138class CSymbianCertificateRetriever : public CActive
139{
140public:
141 static CSymbianCertificateRetriever* NewL();
142 ~CSymbianCertificateRetriever();
143
144 int GetCertificates(QList<QByteArray> &aCertificates);
145
146private:
147 void ConstructL();
148 CSymbianCertificateRetriever();
149 static TInt ThreadEntryPoint(TAny* aParams);
150 void doThreadEntryL();
151 void GetCertificateL();
152 void DoCancel();
153 void RunL();
154 TInt RunError(TInt aError);
155
156private:
157 enum {
158 Initializing,
159 Listing,
160 RetrievingCertificates
161 } iState;
162
163 RThread iThread;
164 CUnifiedCertStore* iCertStore;
165 RMPointerArray<CCTCertInfo> iCertInfos;
166 CCertAttributeFilter* iCertFilter;
167 TInt iCurrentCertIndex;
168 QByteArray iCertificateData;
169 TPtr8 iCertificatePtr;
170 QList<QByteArray>* iCertificates;
171 TInt iSequenceError;
172};
173
174
175#endif
176
177
178QT_END_NAMESPACE
179
180#endif
Note: See TracBrowser for help on using the repository browser.