Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(925)

Unified Diff: net/socket/ssl_server_socket_impl.cc

Issue 2786173003: Convert android to use X509CertificateBytes instead of X509CertificateOpenSSL. (Closed)
Patch Set: ssl_server_socket_impl.cc simplifications Created 3 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « net/cert/ct_objects_extractor.cc ('k') | net/ssl/openssl_client_key_store.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: net/socket/ssl_server_socket_impl.cc
diff --git a/net/socket/ssl_server_socket_impl.cc b/net/socket/ssl_server_socket_impl.cc
index 9b3cfd303d1a48e407e7ba8565d706b7f87189bc..5d4bce72d7b1f8432f8588dcbd05bcd7d85b309b 100644
--- a/net/socket/ssl_server_socket_impl.cc
+++ b/net/socket/ssl_server_socket_impl.cc
@@ -14,6 +14,7 @@
#include "net/base/net_errors.h"
#include "net/cert/cert_verify_result.h"
#include "net/cert/client_cert_verifier.h"
+#include "net/cert/x509_util.h"
#include "net/cert/x509_util_openssl.h"
#include "net/log/net_log_event_type.h"
#include "net/log/net_log_with_source.h"
@@ -624,6 +625,8 @@ SSLServerContextImpl::SSLServerContextImpl(
uint8_t session_ctx_id = 0;
SSL_CTX_set_session_id_context(ssl_ctx_.get(), &session_ctx_id,
sizeof(session_ctx_id));
+ // Deduplicate all certificates minted from the SSL_CTX in memory.
+ SSL_CTX_set0_buffer_pool(ssl_ctx_.get(), x509_util::GetBufferPool());
int verify_mode = 0;
switch (ssl_server_config_.client_cert_type) {
@@ -643,26 +646,26 @@ SSLServerContextImpl::SSLServerContextImpl(
// Set certificate and private key.
DCHECK(cert_->os_cert_handle());
-#if defined(USE_OPENSSL_CERTS)
+ DCHECK(key_->key());
+#if BUILDFLAG(USE_BYTE_CERTS)
+ // On success, SSL_CTX_set_chain_and_key acquires a reference to
+ // |cert_->os_cert_handle()| and |key_->key()|.
+ CRYPTO_BUFFER* cert_buffers[] = {cert_->os_cert_handle()};
+ CHECK(SSL_CTX_set_chain_and_key(ssl_ctx_.get(), cert_buffers,
+ arraysize(cert_buffers), key_->key(),
+ nullptr /* privkey_method */));
+#elif defined(USE_OPENSSL_CERTS)
CHECK(SSL_CTX_use_certificate(ssl_ctx_.get(), cert_->os_cert_handle()));
+ CHECK(SSL_CTX_use_PrivateKey(ssl_ctx_.get(), key_->key()));
#else
- // Convert OSCertHandle to X509 structure.
std::string der_string;
CHECK(X509Certificate::GetDEREncoded(cert_->os_cert_handle(), &der_string));
-
- const unsigned char* der_string_array =
- reinterpret_cast<const unsigned char*>(der_string.data());
-
- bssl::UniquePtr<X509> x509(
- d2i_X509(NULL, &der_string_array, der_string.length()));
- CHECK(x509);
-
- // On success, SSL_CTX_use_certificate acquires a reference to |x509|.
- CHECK(SSL_CTX_use_certificate(ssl_ctx_.get(), x509.get()));
-#endif // USE_OPENSSL_CERTS
-
- DCHECK(key_->key());
+ CHECK(SSL_CTX_use_certificate_ASN1(
+ ssl_ctx_.get(), der_string.length(),
+ reinterpret_cast<const unsigned char*>(der_string.data())));
+ // On success, SSL_CTX_use_PrivateKey acquires a reference to |key_->key()|.
CHECK(SSL_CTX_use_PrivateKey(ssl_ctx_.get(), key_->key()));
+#endif // USE_OPENSSL_CERTS && !USE_BYTE_CERTS
DCHECK_LT(SSL3_VERSION, ssl_server_config_.version_min);
DCHECK_LT(SSL3_VERSION, ssl_server_config_.version_max);
« no previous file with comments | « net/cert/ct_objects_extractor.cc ('k') | net/ssl/openssl_client_key_store.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698