Chromium Code Reviews| Index: net/socket/ssl_server_socket.h |
| diff --git a/net/socket/ssl_server_socket.h b/net/socket/ssl_server_socket.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..7c44a9c88bed737a65e935135580f336666e715e |
| --- /dev/null |
| +++ b/net/socket/ssl_server_socket.h |
| @@ -0,0 +1,53 @@ |
| +// Copyright (c) 2010 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#ifndef NET_SOCKET_SSL_SERVER_SOCKET_H_ |
| +#define NET_SOCKET_SSL_SERVER_SOCKET_H_ |
| + |
| +#include "base/basictypes.h" |
| +#include "net/base/completion_callback.h" |
| +#include "net/socket/socket.h" |
| + |
| +namespace base { |
| +class RSAPrivateKey; |
| +} // namespace base |
| + |
| +namespace net { |
| + |
| +class IOBuffer; |
| +class X509Certificate; |
| + |
| +// SSLServerSocket takes an already connected socket and performs SSL on top of |
| +// it. |
| +// |
| +// This class is designed to work in peer-to-peer connection in pair with |
|
agl
2010/12/17 18:30:50
s/in/in a/
|
| +// SSLClientSocket and is not intended to be used as a standaline SSL server. |
|
wtc
2010/12/17 18:08:04
Remove "in pair with SSLClientSocket", because the
agl
2010/12/17 18:30:50
s/standaline/standalone/
Alpha Left Google
2010/12/17 20:31:12
Done.
Alpha Left Google
2010/12/17 20:31:12
Done.
|
| +class SSLServerSocket : public Socket { |
| + public: |
| + virtual ~SSLServerSocket() {} |
| + |
| + // Performs SSL server handshaking on an existing socket. The socket given |
|
agl
2010/12/17 18:30:50
"Performs an SSL server handshake on the existing
Alpha Left Google
2010/12/17 20:31:12
Done.
|
| + // to this object has to be already connected. |
| + // |
| + // This method takes a callback. Return true value of this method is the |
|
agl
2010/12/17 18:30:50
"Accept either returns ERR_IO_PENDING, in which ca
Alpha Left Google
2010/12/17 20:31:12
Done.
|
| + // error code of the handshaking operation. If the return value is |
| + // net::ERR_IO_PENDING the given callback will be invoked in the future with |
| + // an error code. Other values of error code returned by this method indicate |
| + // the handshaking operation has completed synchronously. |
| + virtual int Accept(CompletionCallback* callback) = 0; |
| +}; |
| + |
| +// Creates an SSL server socket using an already connected socket. A certificate |
| +// and private key needs to be provided. |
| +// |
| +// This created server socket will take ownership of |socket|. However |key| |
| +// is copied. |
| +// TODO(hclam): Defines ServerSocketFactory to create SSLServerSocket. This will |
| +// make mocking easier. |
| +SSLServerSocket* CreateSSLServerSocket( |
| + Socket* socket, X509Certificate* certificate, base::RSAPrivateKey* key); |
| + |
| +} // namespace net |
| + |
| +#endif // NET_SOCKET_SSL_SERVER_SOCKET_NSS_H_ |