blob: 8930f2185d8fd2ad5c96b1008aadf6738685198e [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#if HAVE_CONFIG_H
12#include "config.h"
13#endif // HAVE_CONFIG_H
14
15#include "webrtc/base/sslstreamadapter.h"
16#include "webrtc/base/sslconfig.h"
17
18#if SSL_USE_SCHANNEL
19
20// SChannel support for DTLS and peer-to-peer mode are not
21// done.
22#elif SSL_USE_OPENSSL // && !SSL_USE_SCHANNEL
23
24#include "webrtc/base/opensslstreamadapter.h"
25
torbjorng07d09362015-09-22 11:58:04 -070026#endif // !SSL_USE_OPENSSL && !SSL_USE_SCHANNEL
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000027
28///////////////////////////////////////////////////////////////////////////////
29
30namespace rtc {
31
Guo-wei Shieh456696a2015-09-30 21:48:54 -070032// TODO(guoweis): Move this to SDP layer and use int form internally.
33// webrtc:5043.
34const char CS_AES_CM_128_HMAC_SHA1_80[] = "AES_CM_128_HMAC_SHA1_80";
35const char CS_AES_CM_128_HMAC_SHA1_32[] = "AES_CM_128_HMAC_SHA1_32";
36
37uint16_t GetSrtpCryptoSuiteFromName(const std::string& cipher) {
38 if (cipher == CS_AES_CM_128_HMAC_SHA1_32)
39 return SRTP_AES128_CM_SHA1_32;
40 if (cipher == CS_AES_CM_128_HMAC_SHA1_80)
41 return SRTP_AES128_CM_SHA1_80;
42 return 0;
43}
44
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000045SSLStreamAdapter* SSLStreamAdapter::Create(StreamInterface* stream) {
46#if SSL_USE_SCHANNEL
47 return NULL;
48#elif SSL_USE_OPENSSL // !SSL_USE_SCHANNEL
49 return new OpenSSLStreamAdapter(stream);
torbjorng07d09362015-09-22 11:58:04 -070050#else // !SSL_USE_SCHANNEL && !SSL_USE_OPENSSL
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000051 return NULL;
52#endif
53}
54
Guo-wei Shieh456696a2015-09-30 21:48:54 -070055bool SSLStreamAdapter::GetSslCipherSuite(uint16_t* cipher) {
kwiberg@webrtc.org67186fe2015-03-09 22:21:53 +000056 return false;
57}
58
59bool SSLStreamAdapter::ExportKeyingMaterial(const std::string& label,
60 const uint8* context,
61 size_t context_len,
62 bool use_context,
63 uint8* result,
64 size_t result_len) {
65 return false; // Default is unsupported
66}
67
68bool SSLStreamAdapter::SetDtlsSrtpCiphers(
69 const std::vector<std::string>& ciphers) {
70 return false;
71}
72
73bool SSLStreamAdapter::GetDtlsSrtpCipher(std::string* cipher) {
74 return false;
75}
76
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000077// Note: this matches the logic above with SCHANNEL dominating
78#if SSL_USE_SCHANNEL
79bool SSLStreamAdapter::HaveDtls() { return false; }
80bool SSLStreamAdapter::HaveDtlsSrtp() { return false; }
81bool SSLStreamAdapter::HaveExporter() { return false; }
Guo-wei Shieh456696a2015-09-30 21:48:54 -070082uint16_t SSLStreamAdapter::GetDefaultSslCipherForTest(
83 SSLProtocolVersion version,
84 KeyType key_type) {
85 return 0;
pthatcher@webrtc.org3ee4fe52015-02-11 22:34:36 +000086}
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000087#elif SSL_USE_OPENSSL
88bool SSLStreamAdapter::HaveDtls() {
89 return OpenSSLStreamAdapter::HaveDtls();
90}
91bool SSLStreamAdapter::HaveDtlsSrtp() {
92 return OpenSSLStreamAdapter::HaveDtlsSrtp();
93}
94bool SSLStreamAdapter::HaveExporter() {
95 return OpenSSLStreamAdapter::HaveExporter();
96}
Guo-wei Shieh456696a2015-09-30 21:48:54 -070097uint16_t SSLStreamAdapter::GetDefaultSslCipherForTest(
98 SSLProtocolVersion version,
99 KeyType key_type) {
100 return OpenSSLStreamAdapter::GetDefaultSslCipherForTest(version, key_type);
101}
102
103std::string SSLStreamAdapter::GetSslCipherSuiteName(uint16_t cipher) {
104 return OpenSSLStreamAdapter::GetSslCipherSuiteName(cipher);
pthatcher@webrtc.org3ee4fe52015-02-11 22:34:36 +0000105}
torbjorng07d09362015-09-22 11:58:04 -0700106#endif // !SSL_USE_SCHANNEL && !SSL_USE_OPENSSL
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000107
108///////////////////////////////////////////////////////////////////////////////
109
110} // namespace rtc