blob: 0f351941cab8a1e6e28010658e50f9e883239527 [file] [log] [blame]
// Copyright (c) 2011 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_CLIENT_SOCKET_FACTORY_H_
#define NET_SOCKET_CLIENT_SOCKET_FACTORY_H_
#pragma once
#include <string>
#include "base/basictypes.h"
#include "net/base/net_export.h"
#include "net/base/net_log.h"
#include "net/base/rand_callback.h"
#include "net/udp/datagram_socket.h"
namespace net {
class AddressList;
class CertVerifier;
class ClientSocketHandle;
class DatagramClientSocket;
class DnsCertProvenanceChecker;
class HostPortPair;
class SSLClientSocket;
struct SSLClientSocketContext;
struct SSLConfig;
class SSLHostInfo;
class StreamSocket;
// An interface used to instantiate StreamSocket objects. Used to facilitate
// testing code with mock socket implementations.
class NET_EXPORT ClientSocketFactory {
public:
virtual ~ClientSocketFactory() {}
// |source| is the NetLog::Source for the entity trying to create the socket,
// if it has one.
virtual DatagramClientSocket* CreateDatagramClientSocket(
DatagramSocket::BindType bind_type,
const RandIntCallback& rand_int_cb,
NetLog* net_log,
const NetLog::Source& source) = 0;
virtual StreamSocket* CreateTransportClientSocket(
const AddressList& addresses,
NetLog* net_log,
const NetLog::Source& source) = 0;
// It is allowed to pass in a |transport_socket| that is not obtained from a
// socket pool. The caller could create a ClientSocketHandle directly and call
// set_socket() on it to set a valid StreamSocket instance.
virtual SSLClientSocket* CreateSSLClientSocket(
ClientSocketHandle* transport_socket,
const HostPortPair& host_and_port,
const SSLConfig& ssl_config,
SSLHostInfo* ssl_host_info,
const SSLClientSocketContext& context) = 0;
// Deprecated function (http://crbug.com/37810) that takes a StreamSocket.
virtual SSLClientSocket* CreateSSLClientSocket(
StreamSocket* transport_socket,
const HostPortPair& host_and_port,
const SSLConfig& ssl_config,
SSLHostInfo* ssl_host_info,
const SSLClientSocketContext& context);
// Clears cache used for SSL session resumption.
virtual void ClearSSLSessionCache() = 0;
// Returns the default ClientSocketFactory.
static ClientSocketFactory* GetDefaultFactory();
// Instructs the default ClientSocketFactory to use the system SSL library.
static void UseSystemSSL();
};
} // namespace net
#endif // NET_SOCKET_CLIENT_SOCKET_FACTORY_H_