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

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

Issue 5386001: Cache certificate verification results in memory. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Upload before checkin Created 10 years 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 | Annotate | Revision Log
« no previous file with comments | « net/socket/ssl_client_socket_openssl.cc ('k') | net/socket/ssl_client_socket_pool.cc » ('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) 2010 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2010 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_CLIENT_SOCKET_POOL_H_ 5 #ifndef NET_SOCKET_SSL_CLIENT_SOCKET_POOL_H_
6 #define NET_SOCKET_SSL_CLIENT_SOCKET_POOL_H_ 6 #define NET_SOCKET_SSL_CLIENT_SOCKET_POOL_H_
7 #pragma once 7 #pragma once
8 8
9 #include <string> 9 #include <string>
10 10
11 #include "base/ref_counted.h" 11 #include "base/ref_counted.h"
12 #include "base/scoped_ptr.h" 12 #include "base/scoped_ptr.h"
13 #include "base/time.h" 13 #include "base/time.h"
14 #include "net/base/host_resolver.h" 14 #include "net/base/host_resolver.h"
15 #include "net/base/ssl_config_service.h" 15 #include "net/base/ssl_config_service.h"
16 #include "net/http/http_response_info.h" 16 #include "net/http/http_response_info.h"
17 #include "net/proxy/proxy_server.h" 17 #include "net/proxy/proxy_server.h"
18 #include "net/socket/ssl_client_socket.h" 18 #include "net/socket/ssl_client_socket.h"
19 #include "net/socket/client_socket_pool_base.h" 19 #include "net/socket/client_socket_pool_base.h"
20 #include "net/socket/client_socket_pool_histograms.h" 20 #include "net/socket/client_socket_pool_histograms.h"
21 #include "net/socket/client_socket_pool.h" 21 #include "net/socket/client_socket_pool.h"
22 22
23 namespace net { 23 namespace net {
24 24
25 class CertVerifier;
25 class ClientSocketFactory; 26 class ClientSocketFactory;
26 class ConnectJobFactory; 27 class ConnectJobFactory;
27 class DnsCertProvenanceChecker; 28 class DnsCertProvenanceChecker;
28 class DnsRRResolver; 29 class DnsRRResolver;
29 class HostPortPair; 30 class HostPortPair;
30 class HttpProxyClientSocketPool; 31 class HttpProxyClientSocketPool;
31 class HttpProxySocketParams; 32 class HttpProxySocketParams;
32 class SOCKSClientSocketPool; 33 class SOCKSClientSocketPool;
33 class SOCKSSocketParams; 34 class SOCKSSocketParams;
34 class SSLClientSocket; 35 class SSLClientSocket;
(...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after
88 public: 89 public:
89 SSLConnectJob( 90 SSLConnectJob(
90 const std::string& group_name, 91 const std::string& group_name,
91 const scoped_refptr<SSLSocketParams>& params, 92 const scoped_refptr<SSLSocketParams>& params,
92 const base::TimeDelta& timeout_duration, 93 const base::TimeDelta& timeout_duration,
93 TCPClientSocketPool* tcp_pool, 94 TCPClientSocketPool* tcp_pool,
94 SOCKSClientSocketPool* socks_pool, 95 SOCKSClientSocketPool* socks_pool,
95 HttpProxyClientSocketPool* http_proxy_pool, 96 HttpProxyClientSocketPool* http_proxy_pool,
96 ClientSocketFactory* client_socket_factory, 97 ClientSocketFactory* client_socket_factory,
97 HostResolver* host_resolver, 98 HostResolver* host_resolver,
99 CertVerifier* cert_verifier,
98 DnsRRResolver* dnsrr_resolver, 100 DnsRRResolver* dnsrr_resolver,
99 DnsCertProvenanceChecker* dns_cert_checker, 101 DnsCertProvenanceChecker* dns_cert_checker,
100 SSLHostInfoFactory* ssl_host_info_factory, 102 SSLHostInfoFactory* ssl_host_info_factory,
101 Delegate* delegate, 103 Delegate* delegate,
102 NetLog* net_log); 104 NetLog* net_log);
103 virtual ~SSLConnectJob(); 105 virtual ~SSLConnectJob();
104 106
105 // ConnectJob methods. 107 // ConnectJob methods.
106 virtual LoadState GetLoadState() const; 108 virtual LoadState GetLoadState() const;
107 109
(...skipping 29 matching lines...) Expand all
137 int DoTunnelConnect(); 139 int DoTunnelConnect();
138 int DoTunnelConnectComplete(int result); 140 int DoTunnelConnectComplete(int result);
139 int DoSSLConnect(); 141 int DoSSLConnect();
140 int DoSSLConnectComplete(int result); 142 int DoSSLConnectComplete(int result);
141 143
142 scoped_refptr<SSLSocketParams> params_; 144 scoped_refptr<SSLSocketParams> params_;
143 TCPClientSocketPool* const tcp_pool_; 145 TCPClientSocketPool* const tcp_pool_;
144 SOCKSClientSocketPool* const socks_pool_; 146 SOCKSClientSocketPool* const socks_pool_;
145 HttpProxyClientSocketPool* const http_proxy_pool_; 147 HttpProxyClientSocketPool* const http_proxy_pool_;
146 ClientSocketFactory* const client_socket_factory_; 148 ClientSocketFactory* const client_socket_factory_;
147 HostResolver* const resolver_; 149 HostResolver* const host_resolver_;
150 CertVerifier* const cert_verifier_;
148 DnsRRResolver* const dnsrr_resolver_; 151 DnsRRResolver* const dnsrr_resolver_;
149 DnsCertProvenanceChecker* dns_cert_checker_; 152 DnsCertProvenanceChecker* dns_cert_checker_;
150 SSLHostInfoFactory* const ssl_host_info_factory_; 153 SSLHostInfoFactory* const ssl_host_info_factory_;
151 154
152 State next_state_; 155 State next_state_;
153 CompletionCallbackImpl<SSLConnectJob> callback_; 156 CompletionCallbackImpl<SSLConnectJob> callback_;
154 scoped_ptr<ClientSocketHandle> transport_socket_handle_; 157 scoped_ptr<ClientSocketHandle> transport_socket_handle_;
155 scoped_ptr<SSLClientSocket> ssl_socket_; 158 scoped_ptr<SSLClientSocket> ssl_socket_;
156 scoped_ptr<SSLHostInfo> ssl_host_info_; 159 scoped_ptr<SSLHostInfo> ssl_host_info_;
157 160
158 // The time the DoSSLConnect() method was called. 161 // The time the DoSSLConnect() method was called.
159 base::TimeTicks ssl_connect_start_time_; 162 base::TimeTicks ssl_connect_start_time_;
160 163
161 HttpResponseInfo error_response_info_; 164 HttpResponseInfo error_response_info_;
162 165
163 DISALLOW_COPY_AND_ASSIGN(SSLConnectJob); 166 DISALLOW_COPY_AND_ASSIGN(SSLConnectJob);
164 }; 167 };
165 168
166 class SSLClientSocketPool : public ClientSocketPool, 169 class SSLClientSocketPool : public ClientSocketPool,
167 public SSLConfigService::Observer { 170 public SSLConfigService::Observer {
168 public: 171 public:
169 // Only the pools that will be used are required. i.e. if you never 172 // Only the pools that will be used are required. i.e. if you never
170 // try to create an SSL over SOCKS socket, |socks_pool| may be NULL. 173 // try to create an SSL over SOCKS socket, |socks_pool| may be NULL.
171 SSLClientSocketPool( 174 SSLClientSocketPool(
172 int max_sockets, 175 int max_sockets,
173 int max_sockets_per_group, 176 int max_sockets_per_group,
174 ClientSocketPoolHistograms* histograms, 177 ClientSocketPoolHistograms* histograms,
175 HostResolver* host_resolver, 178 HostResolver* host_resolver,
179 CertVerifier* cert_verifier,
176 DnsRRResolver* dnsrr_resolver, 180 DnsRRResolver* dnsrr_resolver,
177 DnsCertProvenanceChecker* dns_cert_checker, 181 DnsCertProvenanceChecker* dns_cert_checker,
178 SSLHostInfoFactory* ssl_host_info_factory, 182 SSLHostInfoFactory* ssl_host_info_factory,
179 ClientSocketFactory* client_socket_factory, 183 ClientSocketFactory* client_socket_factory,
180 TCPClientSocketPool* tcp_pool, 184 TCPClientSocketPool* tcp_pool,
181 SOCKSClientSocketPool* socks_pool, 185 SOCKSClientSocketPool* socks_pool,
182 HttpProxyClientSocketPool* http_proxy_pool, 186 HttpProxyClientSocketPool* http_proxy_pool,
183 SSLConfigService* ssl_config_service, 187 SSLConfigService* ssl_config_service,
184 NetLog* net_log); 188 NetLog* net_log);
185 189
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after
234 typedef ClientSocketPoolBase<SSLSocketParams> PoolBase; 238 typedef ClientSocketPoolBase<SSLSocketParams> PoolBase;
235 239
236 class SSLConnectJobFactory : public PoolBase::ConnectJobFactory { 240 class SSLConnectJobFactory : public PoolBase::ConnectJobFactory {
237 public: 241 public:
238 SSLConnectJobFactory( 242 SSLConnectJobFactory(
239 TCPClientSocketPool* tcp_pool, 243 TCPClientSocketPool* tcp_pool,
240 SOCKSClientSocketPool* socks_pool, 244 SOCKSClientSocketPool* socks_pool,
241 HttpProxyClientSocketPool* http_proxy_pool, 245 HttpProxyClientSocketPool* http_proxy_pool,
242 ClientSocketFactory* client_socket_factory, 246 ClientSocketFactory* client_socket_factory,
243 HostResolver* host_resolver, 247 HostResolver* host_resolver,
248 CertVerifier* cert_verifier,
244 DnsRRResolver* dnsrr_resolver, 249 DnsRRResolver* dnsrr_resolver,
245 DnsCertProvenanceChecker* dns_cert_checker, 250 DnsCertProvenanceChecker* dns_cert_checker,
246 SSLHostInfoFactory* ssl_host_info_factory, 251 SSLHostInfoFactory* ssl_host_info_factory,
247 NetLog* net_log); 252 NetLog* net_log);
248 253
249 virtual ~SSLConnectJobFactory() {} 254 virtual ~SSLConnectJobFactory() {}
250 255
251 // ClientSocketPoolBase::ConnectJobFactory methods. 256 // ClientSocketPoolBase::ConnectJobFactory methods.
252 virtual ConnectJob* NewConnectJob( 257 virtual ConnectJob* NewConnectJob(
253 const std::string& group_name, 258 const std::string& group_name,
254 const PoolBase::Request& request, 259 const PoolBase::Request& request,
255 ConnectJob::Delegate* delegate) const; 260 ConnectJob::Delegate* delegate) const;
256 261
257 virtual base::TimeDelta ConnectionTimeout() const { return timeout_; } 262 virtual base::TimeDelta ConnectionTimeout() const { return timeout_; }
258 263
259 private: 264 private:
260 TCPClientSocketPool* const tcp_pool_; 265 TCPClientSocketPool* const tcp_pool_;
261 SOCKSClientSocketPool* const socks_pool_; 266 SOCKSClientSocketPool* const socks_pool_;
262 HttpProxyClientSocketPool* const http_proxy_pool_; 267 HttpProxyClientSocketPool* const http_proxy_pool_;
263 ClientSocketFactory* const client_socket_factory_; 268 ClientSocketFactory* const client_socket_factory_;
264 HostResolver* const host_resolver_; 269 HostResolver* const host_resolver_;
270 CertVerifier* const cert_verifier_;
265 DnsRRResolver* const dnsrr_resolver_; 271 DnsRRResolver* const dnsrr_resolver_;
266 DnsCertProvenanceChecker* const dns_cert_checker_; 272 DnsCertProvenanceChecker* const dns_cert_checker_;
267 SSLHostInfoFactory* const ssl_host_info_factory_; 273 SSLHostInfoFactory* const ssl_host_info_factory_;
268 base::TimeDelta timeout_; 274 base::TimeDelta timeout_;
269 NetLog* net_log_; 275 NetLog* net_log_;
270 276
271 DISALLOW_COPY_AND_ASSIGN(SSLConnectJobFactory); 277 DISALLOW_COPY_AND_ASSIGN(SSLConnectJobFactory);
272 }; 278 };
273 279
274 TCPClientSocketPool* const tcp_pool_; 280 TCPClientSocketPool* const tcp_pool_;
275 SOCKSClientSocketPool* const socks_pool_; 281 SOCKSClientSocketPool* const socks_pool_;
276 HttpProxyClientSocketPool* const http_proxy_pool_; 282 HttpProxyClientSocketPool* const http_proxy_pool_;
277 PoolBase base_; 283 PoolBase base_;
278 const scoped_refptr<SSLConfigService> ssl_config_service_; 284 const scoped_refptr<SSLConfigService> ssl_config_service_;
279 285
280 DISALLOW_COPY_AND_ASSIGN(SSLClientSocketPool); 286 DISALLOW_COPY_AND_ASSIGN(SSLClientSocketPool);
281 }; 287 };
282 288
283 REGISTER_SOCKET_PARAMS_FOR_POOL(SSLClientSocketPool, SSLSocketParams); 289 REGISTER_SOCKET_PARAMS_FOR_POOL(SSLClientSocketPool, SSLSocketParams);
284 290
285 } // namespace net 291 } // namespace net
286 292
287 #endif // NET_SOCKET_SSL_CLIENT_SOCKET_POOL_H_ 293 #endif // NET_SOCKET_SSL_CLIENT_SOCKET_POOL_H_
OLDNEW
« no previous file with comments | « net/socket/ssl_client_socket_openssl.cc ('k') | net/socket/ssl_client_socket_pool.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698