2014-05-13 18:00:26 +00:00
|
|
|
/*
|
|
|
|
|
* Copyright 2004 The WebRTC Project Authors. All rights reserved.
|
|
|
|
|
*
|
|
|
|
|
* Use of this source code is governed by a BSD-style license
|
|
|
|
|
* that can be found in the LICENSE file in the root of the source
|
|
|
|
|
* tree. An additional intellectual property rights grant can be found
|
|
|
|
|
* in the file PATENTS. All contributing project authors may
|
|
|
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#if HAVE_CONFIG_H
|
|
|
|
|
#include "config.h"
|
|
|
|
|
#endif // HAVE_CONFIG_H
|
|
|
|
|
|
|
|
|
|
#include "webrtc/base/sslstreamadapter.h"
|
|
|
|
|
#include "webrtc/base/sslconfig.h"
|
|
|
|
|
|
|
|
|
|
#if SSL_USE_SCHANNEL
|
|
|
|
|
|
|
|
|
|
// SChannel support for DTLS and peer-to-peer mode are not
|
|
|
|
|
// done.
|
|
|
|
|
#elif SSL_USE_OPENSSL // && !SSL_USE_SCHANNEL
|
|
|
|
|
|
|
|
|
|
#include "webrtc/base/opensslstreamadapter.h"
|
|
|
|
|
|
2015-09-22 11:58:04 -07:00
|
|
|
#endif // !SSL_USE_OPENSSL && !SSL_USE_SCHANNEL
|
2014-05-13 18:00:26 +00:00
|
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
|
namespace rtc {
|
|
|
|
|
|
2015-09-30 21:48:54 -07:00
|
|
|
// TODO(guoweis): Move this to SDP layer and use int form internally.
|
|
|
|
|
// webrtc:5043.
|
|
|
|
|
const char CS_AES_CM_128_HMAC_SHA1_80[] = "AES_CM_128_HMAC_SHA1_80";
|
|
|
|
|
const char CS_AES_CM_128_HMAC_SHA1_32[] = "AES_CM_128_HMAC_SHA1_32";
|
|
|
|
|
|
2015-10-05 12:43:27 -07:00
|
|
|
int GetSrtpCryptoSuiteFromName(const std::string& cipher) {
|
2015-09-30 21:48:54 -07:00
|
|
|
if (cipher == CS_AES_CM_128_HMAC_SHA1_32)
|
|
|
|
|
return SRTP_AES128_CM_SHA1_32;
|
|
|
|
|
if (cipher == CS_AES_CM_128_HMAC_SHA1_80)
|
|
|
|
|
return SRTP_AES128_CM_SHA1_80;
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
2014-05-13 18:00:26 +00:00
|
|
|
SSLStreamAdapter* SSLStreamAdapter::Create(StreamInterface* stream) {
|
|
|
|
|
#if SSL_USE_SCHANNEL
|
|
|
|
|
return NULL;
|
|
|
|
|
#elif SSL_USE_OPENSSL // !SSL_USE_SCHANNEL
|
|
|
|
|
return new OpenSSLStreamAdapter(stream);
|
2015-09-22 11:58:04 -07:00
|
|
|
#else // !SSL_USE_SCHANNEL && !SSL_USE_OPENSSL
|
2014-05-13 18:00:26 +00:00
|
|
|
return NULL;
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
2015-10-05 12:43:27 -07:00
|
|
|
bool SSLStreamAdapter::GetSslCipherSuite(int* cipher) {
|
2015-03-09 22:21:53 +00:00
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool SSLStreamAdapter::ExportKeyingMaterial(const std::string& label,
|
|
|
|
|
const uint8* context,
|
|
|
|
|
size_t context_len,
|
|
|
|
|
bool use_context,
|
|
|
|
|
uint8* result,
|
|
|
|
|
size_t result_len) {
|
|
|
|
|
return false; // Default is unsupported
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool SSLStreamAdapter::SetDtlsSrtpCiphers(
|
|
|
|
|
const std::vector<std::string>& ciphers) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool SSLStreamAdapter::GetDtlsSrtpCipher(std::string* cipher) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
2014-05-13 18:00:26 +00:00
|
|
|
// Note: this matches the logic above with SCHANNEL dominating
|
|
|
|
|
#if SSL_USE_SCHANNEL
|
|
|
|
|
bool SSLStreamAdapter::HaveDtls() { return false; }
|
|
|
|
|
bool SSLStreamAdapter::HaveDtlsSrtp() { return false; }
|
|
|
|
|
bool SSLStreamAdapter::HaveExporter() { return false; }
|
2015-10-05 12:43:27 -07:00
|
|
|
int SSLStreamAdapter::GetDefaultSslCipherForTest(SSLProtocolVersion version,
|
|
|
|
|
KeyType key_type) {
|
2015-09-30 21:48:54 -07:00
|
|
|
return 0;
|
2015-02-11 22:34:36 +00:00
|
|
|
}
|
2014-05-13 18:00:26 +00:00
|
|
|
#elif SSL_USE_OPENSSL
|
|
|
|
|
bool SSLStreamAdapter::HaveDtls() {
|
|
|
|
|
return OpenSSLStreamAdapter::HaveDtls();
|
|
|
|
|
}
|
|
|
|
|
bool SSLStreamAdapter::HaveDtlsSrtp() {
|
|
|
|
|
return OpenSSLStreamAdapter::HaveDtlsSrtp();
|
|
|
|
|
}
|
|
|
|
|
bool SSLStreamAdapter::HaveExporter() {
|
|
|
|
|
return OpenSSLStreamAdapter::HaveExporter();
|
|
|
|
|
}
|
2015-10-05 12:43:27 -07:00
|
|
|
int SSLStreamAdapter::GetDefaultSslCipherForTest(SSLProtocolVersion version,
|
|
|
|
|
KeyType key_type) {
|
2015-09-30 21:48:54 -07:00
|
|
|
return OpenSSLStreamAdapter::GetDefaultSslCipherForTest(version, key_type);
|
|
|
|
|
}
|
|
|
|
|
|
2015-10-05 12:43:27 -07:00
|
|
|
std::string SSLStreamAdapter::GetSslCipherSuiteName(int cipher) {
|
2015-09-30 21:48:54 -07:00
|
|
|
return OpenSSLStreamAdapter::GetSslCipherSuiteName(cipher);
|
2015-02-11 22:34:36 +00:00
|
|
|
}
|
2015-09-22 11:58:04 -07:00
|
|
|
#endif // !SSL_USE_SCHANNEL && !SSL_USE_OPENSSL
|
2014-05-13 18:00:26 +00:00
|
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
|
} // namespace rtc
|