blob: 14d8bea4f5ff7aafda9ee714d5064e346a768841 [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);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000030
31 OpenSSLAdapter(AsyncSocket* socket);
kwiberg@webrtc.org67186fe2015-03-09 22:21:53 +000032 ~OpenSSLAdapter() override;
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000033
kwiberg@webrtc.org67186fe2015-03-09 22:21:53 +000034 void SetMode(SSLMode mode) override;
35 int StartSSL(const char* hostname, bool restartable) override;
36 int Send(const void* pv, size_t cb) override;
37 int SendTo(const void* pv, size_t cb, const SocketAddress& addr) override;
38 int Recv(void* pv, size_t cb) override;
39 int RecvFrom(void* pv, size_t cb, SocketAddress* paddr) override;
40 int Close() override;
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000041
42 // Note that the socket returns ST_CONNECTING while SSL is being negotiated.
kwiberg@webrtc.org67186fe2015-03-09 22:21:53 +000043 ConnState GetState() const override;
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000044
45protected:
kwiberg@webrtc.org67186fe2015-03-09 22:21:53 +000046 void OnConnectEvent(AsyncSocket* socket) override;
47 void OnReadEvent(AsyncSocket* socket) override;
48 void OnWriteEvent(AsyncSocket* socket) override;
49 void OnCloseEvent(AsyncSocket* socket, int err) override;
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000050
51private:
52 enum SSLState {
53 SSL_NONE, SSL_WAIT, SSL_CONNECTING, SSL_CONNECTED, SSL_ERROR
54 };
55
pthatcher@webrtc.orga9b1ec02014-12-29 23:00:14 +000056 enum { MSG_TIMEOUT };
57
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000058 int BeginSSL();
59 int ContinueSSL();
60 void Error(const char* context, int err, bool signal = true);
61 void Cleanup();
62
kwiberg@webrtc.org67186fe2015-03-09 22:21:53 +000063 void OnMessage(Message* msg) override;
pthatcher@webrtc.orga9b1ec02014-12-29 23:00:14 +000064
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000065 static bool VerifyServerName(SSL* ssl, const char* host,
66 bool ignore_bad_cert);
67 bool SSLPostConnectionCheck(SSL* ssl, const char* host);
tfarinaa41ab932015-10-30 16:08:48 -070068#if !defined(NDEBUG)
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000069 static void SSLInfoCallback(const SSL* s, int where, int ret);
tfarinaa41ab932015-10-30 16:08:48 -070070#endif
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000071 static int SSLVerifyCallback(int ok, X509_STORE_CTX* store);
72 static VerificationCallback custom_verify_callback_;
73 friend class OpenSSLStreamAdapter; // for custom_verify_callback_;
74
75 static bool ConfigureTrustedRootCertificates(SSL_CTX* ctx);
pthatcher@webrtc.orga9b1ec02014-12-29 23:00:14 +000076 SSL_CTX* SetupSSLContext();
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000077
78 SSLState state_;
79 bool ssl_read_needs_write_;
80 bool ssl_write_needs_read_;
81 // If true, socket will retain SSL configuration after Close.
82 bool restartable_;
83
84 SSL* ssl_;
85 SSL_CTX* ssl_ctx_;
86 std::string ssl_host_name_;
pthatcher@webrtc.orga9b1ec02014-12-29 23:00:14 +000087 // Do DTLS or not
88 SSLMode ssl_mode_;
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000089
90 bool custom_verification_succeeded_;
91};
92
93/////////////////////////////////////////////////////////////////////////////
94
95} // namespace rtc
96
97#endif // WEBRTC_BASE_OPENSSLADAPTER_H__