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

Side by Side Diff: net/socket/ssl_server_socket.h

Issue 1518613002: Support for server session cache. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@client_certs
Patch Set: Remoting: Fixed initialization ordering of socket_ and server_context_ Created 4 years, 9 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 unified diff | Download patch
« no previous file with comments | « no previous file | net/socket/ssl_server_socket_nss.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef NET_SOCKET_SSL_SERVER_SOCKET_H_ 5 #ifndef NET_SOCKET_SSL_SERVER_SOCKET_H_
6 #define NET_SOCKET_SSL_SERVER_SOCKET_H_ 6 #define NET_SOCKET_SSL_SERVER_SOCKET_H_
7 7
8 #include "base/memory/scoped_ptr.h" 8 #include "base/memory/scoped_ptr.h"
9 #include "net/base/completion_callback.h" 9 #include "net/base/completion_callback.h"
10 #include "net/base/net_export.h" 10 #include "net/base/net_export.h"
(...skipping 13 matching lines...) Expand all
24 public: 24 public:
25 ~SSLServerSocket() override {} 25 ~SSLServerSocket() override {}
26 26
27 // Perform the SSL server handshake, and notify the supplied callback 27 // Perform the SSL server handshake, and notify the supplied callback
28 // if the process completes asynchronously. If Disconnect is called before 28 // if the process completes asynchronously. If Disconnect is called before
29 // completion then the callback will be silently, as for other StreamSocket 29 // completion then the callback will be silently, as for other StreamSocket
30 // calls. 30 // calls.
31 virtual int Handshake(const CompletionCallback& callback) = 0; 31 virtual int Handshake(const CompletionCallback& callback) = 0;
32 }; 32 };
33 33
34 class SSLServerContext {
35 public:
36 virtual ~SSLServerContext(){};
37
38 // Creates an SSL server socket over an already-connected transport socket.
39 // The caller must ensure the returned socket does not outlive the server
40 // context.
41 //
42 // The caller starts the SSL server handshake by calling Handshake on the
43 // returned socket.
44 virtual scoped_ptr<SSLServerSocket> CreateSSLServerSocket(
45 scoped_ptr<StreamSocket> socket) = 0;
46 };
47
34 // Configures the underlying SSL library for the use of SSL server sockets. 48 // Configures the underlying SSL library for the use of SSL server sockets.
35 // 49 //
36 // Due to the requirements of the underlying libraries, this should be called 50 // Due to the requirements of the underlying libraries, this should be called
37 // early in process initialization, before any SSL socket, client or server, 51 // early in process initialization, before any SSL socket, client or server,
38 // has been used. 52 // has been used.
39 // 53 //
40 // Note: If a process does not use SSL server sockets, this call may be 54 // Note: If a process does not use SSL server sockets, this call may be
41 // omitted. 55 // omitted.
42 NET_EXPORT void EnableSSLServerSockets(); 56 NET_EXPORT void EnableSSLServerSockets();
43 57
44 // Creates an SSL server socket over an already-connected transport socket. 58 // Creates an SSL server socket context where all sockets spawned using this
59 // context will share the same session cache.
60 //
45 // The caller must provide the server certificate and private key to use. 61 // The caller must provide the server certificate and private key to use.
46 //
47 // The returned SSLServerSocket takes ownership of |socket|. Stubbed versions
48 // of CreateSSLServerSocket will delete |socket| and return NULL.
49 // It takes a reference to |certificate|. 62 // It takes a reference to |certificate|.
50 // The |key| and |ssl_config| parameters are copied. 63 // The |key| and |ssl_config| parameters are copied.
51 // 64 //
52 // The caller starts the SSL server handshake by calling Handshake on the 65 NET_EXPORT scoped_ptr<SSLServerContext> CreateSSLServerContext(
53 // returned socket.
54 NET_EXPORT scoped_ptr<SSLServerSocket> CreateSSLServerSocket(
55 scoped_ptr<StreamSocket> socket,
56 X509Certificate* certificate, 66 X509Certificate* certificate,
57 const crypto::RSAPrivateKey& key, 67 const crypto::RSAPrivateKey& key,
58 const SSLServerConfig& ssl_config); 68 const SSLServerConfig& ssl_config);
59 69
60 } // namespace net 70 } // namespace net
61 71
62 #endif // NET_SOCKET_SSL_SERVER_SOCKET_H_ 72 #endif // NET_SOCKET_SSL_SERVER_SOCKET_H_
OLDNEW
« no previous file with comments | « no previous file | net/socket/ssl_server_socket_nss.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698