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 3// found in the LICENSE file. 4 5#ifndef NET_SOCKET_SSL_SERVER_SOCKET_H_ 6#define NET_SOCKET_SSL_SERVER_SOCKET_H_ 7 8#include "base/basictypes.h" 9#include "net/base/completion_callback.h" 10#include "net/socket/socket.h" 11 12namespace crypto { 13class RSAPrivateKey; 14} // namespace base 15 16namespace net { 17 18class IOBuffer; 19struct SSLConfig; 20class X509Certificate; 21 22// SSLServerSocket takes an already connected socket and performs SSL on top of 23// it. 24// 25// This class is designed to work in a peer-to-peer connection and is not 26// intended to be used as a standalone SSL server. 27class SSLServerSocket : public Socket { 28 public: 29 virtual ~SSLServerSocket() {} 30 31 // Performs an SSL server handshake on the existing socket. The given socket 32 // must have already been connected. 33 // 34 // Accept either returns ERR_IO_PENDING, in which case the given callback 35 // will be called in the future with the real result, or it completes 36 // synchronously, returning the result immediately. 37 virtual int Accept(CompletionCallback* callback) = 0; 38}; 39 40// Creates an SSL server socket using an already connected socket. A certificate 41// and private key needs to be provided. 42// 43// This created server socket will take ownership of |socket|. However |key| 44// is copied. 45// TODO(hclam): Defines ServerSocketFactory to create SSLServerSocket. This will 46// make mocking easier. 47SSLServerSocket* CreateSSLServerSocket( 48 Socket* socket, X509Certificate* certificate, crypto::RSAPrivateKey* key, 49 const SSLConfig& ssl_config); 50 51} // namespace net 52 53#endif // NET_SOCKET_SSL_SERVER_SOCKET_NSS_H_ 54