blob: 079f0016d0c10482018467a2c3e075a1c18c80f9 [file] [log] [blame]
henrike@webrtc.orgf0488722014-05-13 18:00:26 +00001/*
2 * Copyright 2004 The WebRTC Project Authors. All rights reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11#ifndef WEBRTC_BASE_OPENSSLADAPTER_H__
12#define WEBRTC_BASE_OPENSSLADAPTER_H__
13
14#include <string>
pthatcher@webrtc.orga9b1ec02014-12-29 23:00:14 +000015#include "webrtc/base/messagehandler.h"
16#include "webrtc/base/messagequeue.h"
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000017#include "webrtc/base/ssladapter.h"
18
19typedef struct ssl_st SSL;
20typedef struct ssl_ctx_st SSL_CTX;
21typedef struct x509_store_ctx_st X509_STORE_CTX;
22
23namespace rtc {
24
25///////////////////////////////////////////////////////////////////////////////
26
pthatcher@webrtc.orga9b1ec02014-12-29 23:00:14 +000027class OpenSSLAdapter : public SSLAdapter, public MessageHandler {
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000028public:
29 static bool InitializeSSL(VerificationCallback callback);
30 static bool InitializeSSLThread();
31 static bool CleanupSSL();
32
33 OpenSSLAdapter(AsyncSocket* socket);
34 virtual ~OpenSSLAdapter();
35
pthatcher@webrtc.orga9b1ec02014-12-29 23:00:14 +000036 virtual void SetMode(SSLMode mode);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000037 virtual int StartSSL(const char* hostname, bool restartable);
38 virtual int Send(const void* pv, size_t cb);
pthatcher@webrtc.orga9b1ec02014-12-29 23:00:14 +000039 virtual int SendTo(const void* pv, size_t cb, const SocketAddress& addr);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000040 virtual int Recv(void* pv, size_t cb);
pthatcher@webrtc.orga9b1ec02014-12-29 23:00:14 +000041 virtual int RecvFrom(void* pv, size_t cb, SocketAddress* paddr);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000042 virtual int Close();
43
44 // Note that the socket returns ST_CONNECTING while SSL is being negotiated.
45 virtual ConnState GetState() const;
46
47protected:
48 virtual void OnConnectEvent(AsyncSocket* socket);
49 virtual void OnReadEvent(AsyncSocket* socket);
50 virtual void OnWriteEvent(AsyncSocket* socket);
51 virtual void OnCloseEvent(AsyncSocket* socket, int err);
52
53private:
54 enum SSLState {
55 SSL_NONE, SSL_WAIT, SSL_CONNECTING, SSL_CONNECTED, SSL_ERROR
56 };
57
pthatcher@webrtc.orga9b1ec02014-12-29 23:00:14 +000058 enum { MSG_TIMEOUT };
59
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000060 int BeginSSL();
61 int ContinueSSL();
62 void Error(const char* context, int err, bool signal = true);
63 void Cleanup();
64
pthatcher@webrtc.orga9b1ec02014-12-29 23:00:14 +000065 virtual void OnMessage(Message* msg);
66
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000067 static bool VerifyServerName(SSL* ssl, const char* host,
68 bool ignore_bad_cert);
69 bool SSLPostConnectionCheck(SSL* ssl, const char* host);
70#if _DEBUG
71 static void SSLInfoCallback(const SSL* s, int where, int ret);
72#endif // !_DEBUG
73 static int SSLVerifyCallback(int ok, X509_STORE_CTX* store);
74 static VerificationCallback custom_verify_callback_;
75 friend class OpenSSLStreamAdapter; // for custom_verify_callback_;
76
77 static bool ConfigureTrustedRootCertificates(SSL_CTX* ctx);
pthatcher@webrtc.orga9b1ec02014-12-29 23:00:14 +000078 SSL_CTX* SetupSSLContext();
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000079
80 SSLState state_;
81 bool ssl_read_needs_write_;
82 bool ssl_write_needs_read_;
83 // If true, socket will retain SSL configuration after Close.
84 bool restartable_;
85
86 SSL* ssl_;
87 SSL_CTX* ssl_ctx_;
88 std::string ssl_host_name_;
pthatcher@webrtc.orga9b1ec02014-12-29 23:00:14 +000089 // Do DTLS or not
90 SSLMode ssl_mode_;
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000091
92 bool custom_verification_succeeded_;
93};
94
95/////////////////////////////////////////////////////////////////////////////
96
97} // namespace rtc
98
99#endif // WEBRTC_BASE_OPENSSLADAPTER_H__