This CL adds an API to the SSL stream adapters and transport channels to get the SSL cipher that was negotiated with the remote peer. The previously approved CL https://webrtc-codereview.appspot.com/26009004/ was reverted in https://webrtc-codereview.appspot.com/40689004/ due to compilation issues while rolling into Chromium. As the new method has landed in Chromium in https://crrev.com/bc321c76ace6e1d5a03440e554ccb207159802ec, this should be safe to land here now. BUG=3976 R=pthatcher@webrtc.org Review URL: https://webrtc-codereview.appspot.com/37209004 Cr-Commit-Position: refs/heads/master@{#8343} git-svn-id: http://webrtc.googlecode.com/svn/trunk@8343 4adac7df-926f-26a2-2b94-8c16560cd09d
87 lines
2.6 KiB
C++
87 lines
2.6 KiB
C++
/*
|
|
* 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"
|
|
|
|
#elif SSL_USE_NSS // && !SSL_USE_SCHANNEL && !SSL_USE_OPENSSL
|
|
|
|
#include "webrtc/base/nssstreamadapter.h"
|
|
|
|
#endif // !SSL_USE_OPENSSL && !SSL_USE_SCHANNEL && !SSL_USE_NSS
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
namespace rtc {
|
|
|
|
SSLStreamAdapter* SSLStreamAdapter::Create(StreamInterface* stream) {
|
|
#if SSL_USE_SCHANNEL
|
|
return NULL;
|
|
#elif SSL_USE_OPENSSL // !SSL_USE_SCHANNEL
|
|
return new OpenSSLStreamAdapter(stream);
|
|
#elif SSL_USE_NSS // !SSL_USE_SCHANNEL && !SSL_USE_OPENSSL
|
|
return new NSSStreamAdapter(stream);
|
|
#else // !SSL_USE_SCHANNEL && !SSL_USE_OPENSSL && !SSL_USE_NSS
|
|
return NULL;
|
|
#endif
|
|
}
|
|
|
|
// 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; }
|
|
std::string SSLStreamAdapter::GetDefaultSslCipher() {
|
|
return std::string();
|
|
}
|
|
#elif SSL_USE_OPENSSL
|
|
bool SSLStreamAdapter::HaveDtls() {
|
|
return OpenSSLStreamAdapter::HaveDtls();
|
|
}
|
|
bool SSLStreamAdapter::HaveDtlsSrtp() {
|
|
return OpenSSLStreamAdapter::HaveDtlsSrtp();
|
|
}
|
|
bool SSLStreamAdapter::HaveExporter() {
|
|
return OpenSSLStreamAdapter::HaveExporter();
|
|
}
|
|
std::string SSLStreamAdapter::GetDefaultSslCipher() {
|
|
return OpenSSLStreamAdapter::GetDefaultSslCipher();
|
|
}
|
|
#elif SSL_USE_NSS
|
|
bool SSLStreamAdapter::HaveDtls() {
|
|
return NSSStreamAdapter::HaveDtls();
|
|
}
|
|
bool SSLStreamAdapter::HaveDtlsSrtp() {
|
|
return NSSStreamAdapter::HaveDtlsSrtp();
|
|
}
|
|
bool SSLStreamAdapter::HaveExporter() {
|
|
return NSSStreamAdapter::HaveExporter();
|
|
}
|
|
std::string SSLStreamAdapter::GetDefaultSslCipher() {
|
|
return NSSStreamAdapter::GetDefaultSslCipher();
|
|
}
|
|
#endif // !SSL_USE_SCHANNEL && !SSL_USE_OPENSSL && !SSL_USE_NSS
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
} // namespace rtc
|