OLD | NEW |
---|---|
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/basictypes.h" | 8 #include "base/basictypes.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 Loading... | |
24 public: | 24 public: |
25 virtual ~SSLServerSocket() {} | 25 virtual ~SSLServerSocket() {} |
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 // Configures the underlying SSL library for the use of SSL server sockets. | |
35 // | |
36 // Due to the requirements of the underlying libraries, this should be called | |
37 // early in process initialization, before any SSL socket, client or server, | |
38 // has been used. | |
wtc
2012/06/12 21:29:45
Please add something like:
If a process doesn't
| |
39 NET_EXPORT void EnableSSLServerSockets(); | |
40 | |
34 // Creates an SSL server socket over an already-connected transport socket. | 41 // Creates an SSL server socket over an already-connected transport socket. |
35 // The caller must provide the server certificate and private key to use. | 42 // The caller must provide the server certificate and private key to use. |
36 // | 43 // |
37 // The returned SSLServerSocket takes ownership of |socket|. Stubbed versions | 44 // The returned SSLServerSocket takes ownership of |socket|. Stubbed versions |
38 // of CreateSSLServerSocket will delete |socket| and return NULL. | 45 // of CreateSSLServerSocket will delete |socket| and return NULL. |
39 // It takes a reference to |certificate|. | 46 // It takes a reference to |certificate|. |
40 // The |key| and |ssl_config| parameters are copied. |key| cannot be const | 47 // The |key| and |ssl_config| parameters are copied. |key| cannot be const |
41 // because the methods used to copy its contents are non-const. | 48 // because the methods used to copy its contents are non-const. |
42 // | 49 // |
43 // The caller starts the SSL server handshake by calling Handshake on the | 50 // The caller starts the SSL server handshake by calling Handshake on the |
44 // returned socket. | 51 // returned socket. |
45 NET_EXPORT SSLServerSocket* CreateSSLServerSocket( | 52 NET_EXPORT SSLServerSocket* CreateSSLServerSocket( |
46 StreamSocket* socket, | 53 StreamSocket* socket, |
47 X509Certificate* certificate, | 54 X509Certificate* certificate, |
48 crypto::RSAPrivateKey* key, | 55 crypto::RSAPrivateKey* key, |
49 const SSLConfig& ssl_config); | 56 const SSLConfig& ssl_config); |
50 | 57 |
51 } // namespace net | 58 } // namespace net |
52 | 59 |
53 #endif // NET_SOCKET_SSL_SERVER_SOCKET_H_ | 60 #endif // NET_SOCKET_SSL_SERVER_SOCKET_H_ |
OLD | NEW |