// Copyright 2012 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. // // NOTE: This class is provided to support existing Chromium consumers; it is // NOT intended for use in NEW code. Configuring a TLS server correctly is a // security-sensitive activity with many subtle nuances, and thus care should be // taken to discuss with //net/OWNERS before any new usages. // // As such, this header should be treated as an internal implementation detail // of //net (where it's used for some unit test infrastructure), not as // appropriate for general use. // // See https://crbug.com/621176 for more details. #ifndef NET_SOCKET_SSL_SERVER_SOCKET_H_ #define NET_SOCKET_SSL_SERVER_SOCKET_H_ #include <memory> #include "net/base/completion_once_callback.h" #include "net/base/net_export.h" #include "net/socket/ssl_socket.h" #include "net/socket/stream_socket.h" #include "third_party/boringssl/src/include/openssl/base.h" namespace crypto { class RSAPrivateKey; } // namespace crypto namespace net { struct SSLServerConfig; class SSLPrivateKey; class X509Certificate; // A server socket that uses SSL as the transport layer. class SSLServerSocket : public SSLSocket { … }; class SSLServerContext { … }; // Creates an SSL server socket context where all sockets spawned using this // context will share the same session cache. // // The caller must provide the server certificate and private key to use. // It takes a reference to |certificate| and |pkey|. // The |ssl_config| parameter is copied. // NET_EXPORT std::unique_ptr<SSLServerContext> CreateSSLServerContext( X509Certificate* certificate, EVP_PKEY* pkey, const SSLServerConfig& ssl_config); // As above, but takes an RSAPrivateKey object. Deprecated, use the EVP_PKEY // version instead. // TODO(mattm): convert existing callers and remove this function. NET_EXPORT std::unique_ptr<SSLServerContext> CreateSSLServerContext( X509Certificate* certificate, const crypto::RSAPrivateKey& key, const SSLServerConfig& ssl_config); NET_EXPORT std::unique_ptr<SSLServerContext> CreateSSLServerContext( X509Certificate* certificate, scoped_refptr<SSLPrivateKey> key, const SSLServerConfig& ssl_config); } // namespace net #endif // NET_SOCKET_SSL_SERVER_SOCKET_H_