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

Side by Side Diff: chrome/browser/profiles/profile_impl_io_data.cc

Issue 7827033: Introduce net::HttpServerPropertiesManager to manage server-specific properties. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 9 years, 2 months 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 | « chrome/browser/profiles/profile_impl_io_data.h ('k') | chrome/chrome_browser.gypi » ('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) 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 #include "chrome/browser/profiles/profile_impl_io_data.h" 5 #include "chrome/browser/profiles/profile_impl_io_data.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/command_line.h" 8 #include "base/command_line.h"
9 #include "base/file_util.h" 9 #include "base/file_util.h"
10 #include "base/logging.h" 10 #include "base/logging.h"
11 #include "base/stl_util.h" 11 #include "base/stl_util.h"
12 #include "chrome/browser/io_thread.h" 12 #include "chrome/browser/io_thread.h"
13 #include "chrome/browser/net/chrome_net_log.h" 13 #include "chrome/browser/net/chrome_net_log.h"
14 #include "chrome/browser/net/chrome_network_delegate.h" 14 #include "chrome/browser/net/chrome_network_delegate.h"
15 #include "chrome/browser/net/connect_interceptor.h" 15 #include "chrome/browser/net/connect_interceptor.h"
16 #include "chrome/browser/net/http_server_properties_manager.h"
16 #include "chrome/browser/net/predictor.h" 17 #include "chrome/browser/net/predictor.h"
17 #include "chrome/browser/net/sqlite_origin_bound_cert_store.h" 18 #include "chrome/browser/net/sqlite_origin_bound_cert_store.h"
18 #include "chrome/browser/net/sqlite_persistent_cookie_store.h" 19 #include "chrome/browser/net/sqlite_persistent_cookie_store.h"
19 #include "chrome/browser/prefs/pref_member.h" 20 #include "chrome/browser/prefs/pref_member.h"
20 #include "chrome/browser/profiles/profile.h" 21 #include "chrome/browser/profiles/profile.h"
21 #include "chrome/common/chrome_constants.h" 22 #include "chrome/common/chrome_constants.h"
22 #include "chrome/common/chrome_switches.h" 23 #include "chrome/common/chrome_switches.h"
23 #include "chrome/common/pref_names.h" 24 #include "chrome/common/pref_names.h"
24 #include "chrome/common/url_constants.h" 25 #include "chrome/common/url_constants.h"
25 #include "content/browser/browser_thread.h" 26 #include "content/browser/browser_thread.h"
26 #include "content/browser/resource_context.h" 27 #include "content/browser/resource_context.h"
27 #include "net/base/origin_bound_cert_service.h" 28 #include "net/base/origin_bound_cert_service.h"
28 #include "net/ftp/ftp_network_layer.h" 29 #include "net/ftp/ftp_network_layer.h"
29 #include "net/http/http_cache.h" 30 #include "net/http/http_cache.h"
30 #include "net/url_request/url_request_job_factory.h" 31 #include "net/url_request/url_request_job_factory.h"
31 32
32 namespace { 33 namespace {
33 34
34 void DeleteTransportSecurityStateSinceOnIOThread( 35 void ClearNetworkingHistorySinceOnIOThread(
35 ProfileImplIOData* io_data, base::Time time) { 36 ProfileImplIOData* io_data, base::Time time) {
36 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); 37 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
37 io_data->transport_security_state()->DeleteSince(time); 38 io_data->transport_security_state()->DeleteSince(time);
39 io_data->http_server_properties()->DeleteAll();
38 } 40 }
39 41
40 } // namespace 42 } // namespace
41 43
42 ProfileImplIOData::Handle::Handle(Profile* profile) 44 ProfileImplIOData::Handle::Handle(Profile* profile)
43 : io_data_(new ProfileImplIOData), 45 : io_data_(new ProfileImplIOData),
44 profile_(profile), 46 profile_(profile),
45 initialized_(false) { 47 initialized_(false) {
46 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 48 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
47 DCHECK(profile); 49 DCHECK(profile);
(...skipping 16 matching lines...) Expand all
64 } 66 }
65 67
66 // Clean up all isolated app request contexts. 68 // Clean up all isolated app request contexts.
67 for (ChromeURLRequestContextGetterMap::iterator iter = 69 for (ChromeURLRequestContextGetterMap::iterator iter =
68 app_request_context_getter_map_.begin(); 70 app_request_context_getter_map_.begin();
69 iter != app_request_context_getter_map_.end(); 71 iter != app_request_context_getter_map_.end();
70 ++iter) { 72 ++iter) {
71 iter->second->CleanupOnUIThread(); 73 iter->second->CleanupOnUIThread();
72 } 74 }
73 75
76 if (io_data_->http_server_properties_manager_.get())
77 io_data_->http_server_properties_manager_->ShutdownOnUIThread();
74 io_data_->ShutdownOnUIThread(); 78 io_data_->ShutdownOnUIThread();
75 } 79 }
76 80
77 void ProfileImplIOData::Handle::Init( 81 void ProfileImplIOData::Handle::Init(
78 const FilePath& cookie_path, 82 const FilePath& cookie_path,
79 const FilePath& origin_bound_cert_path, 83 const FilePath& origin_bound_cert_path,
80 const FilePath& cache_path, 84 const FilePath& cache_path,
81 int cache_max_size, 85 int cache_max_size,
82 const FilePath& media_cache_path, 86 const FilePath& media_cache_path,
83 int media_cache_max_size, 87 int media_cache_max_size,
(...skipping 95 matching lines...) Expand 10 before | Expand all | Expand 10 after
179 183
180 184
181 ChromeURLRequestContextGetter* context = 185 ChromeURLRequestContextGetter* context =
182 ChromeURLRequestContextGetter::CreateOriginalForIsolatedApp( 186 ChromeURLRequestContextGetter::CreateOriginalForIsolatedApp(
183 profile_, io_data_, app_id); 187 profile_, io_data_, app_id);
184 app_request_context_getter_map_[app_id] = context; 188 app_request_context_getter_map_[app_id] = context;
185 189
186 return context; 190 return context;
187 } 191 }
188 192
189 void ProfileImplIOData::Handle::DeleteTransportSecurityStateSince( 193 void ProfileImplIOData::Handle::ClearNetworkingHistorySince(
190 base::Time time) { 194 base::Time time) {
191 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 195 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
192 LazyInitialize(); 196 LazyInitialize();
193 197
194 BrowserThread::PostTask( 198 BrowserThread::PostTask(
195 BrowserThread::IO, FROM_HERE, 199 BrowserThread::IO, FROM_HERE,
196 base::Bind( 200 base::Bind(
197 &DeleteTransportSecurityStateSinceOnIOThread, 201 &ClearNetworkingHistorySinceOnIOThread,
198 io_data_, 202 io_data_,
199 time)); 203 time));
200 } 204 }
201 205
202 void ProfileImplIOData::Handle::LazyInitialize() const { 206 void ProfileImplIOData::Handle::LazyInitialize() const {
203 if (!initialized_) { 207 if (!initialized_) {
204 io_data_->InitializeOnUIThread(profile_); 208 io_data_->InitializeOnUIThread(profile_);
209 PrefService* pref_service = profile_->GetPrefs();
210 io_data_->http_server_properties_manager_.reset(
211 new chrome_browser_net::HttpServerPropertiesManager(pref_service));
205 ChromeNetworkDelegate::InitializeReferrersEnabled( 212 ChromeNetworkDelegate::InitializeReferrersEnabled(
206 io_data_->enable_referrers(), profile_->GetPrefs()); 213 io_data_->enable_referrers(), pref_service);
207 io_data_->clear_local_state_on_exit()->Init( 214 io_data_->clear_local_state_on_exit()->Init(
208 prefs::kClearSiteDataOnExit, profile_->GetPrefs(), NULL); 215 prefs::kClearSiteDataOnExit, pref_service, NULL);
209 io_data_->clear_local_state_on_exit()->MoveToThread(BrowserThread::IO); 216 io_data_->clear_local_state_on_exit()->MoveToThread(BrowserThread::IO);
210 #if defined(ENABLE_SAFE_BROWSING) 217 #if defined(ENABLE_SAFE_BROWSING)
211 io_data_->safe_browsing_enabled()->Init(prefs::kSafeBrowsingEnabled, 218 io_data_->safe_browsing_enabled()->Init(prefs::kSafeBrowsingEnabled,
212 profile_->GetPrefs(), NULL); 219 pref_service, NULL);
213 io_data_->safe_browsing_enabled()->MoveToThread(BrowserThread::IO); 220 io_data_->safe_browsing_enabled()->MoveToThread(BrowserThread::IO);
214 #endif 221 #endif
215 initialized_ = true; 222 initialized_ = true;
216 } 223 }
217 } 224 }
218 225
219 ProfileImplIOData::LazyParams::LazyParams() 226 ProfileImplIOData::LazyParams::LazyParams()
220 : cache_max_size(0), 227 : cache_max_size(0),
221 media_cache_max_size(0) {} 228 media_cache_max_size(0) {}
222 ProfileImplIOData::LazyParams::~LazyParams() {} 229 ProfileImplIOData::LazyParams::~LazyParams() {}
(...skipping 18 matching lines...) Expand all
241 bool record_mode = chrome::kRecordModeEnabled && 248 bool record_mode = chrome::kRecordModeEnabled &&
242 command_line.HasSwitch(switches::kRecordMode); 249 command_line.HasSwitch(switches::kRecordMode);
243 bool playback_mode = command_line.HasSwitch(switches::kPlaybackMode); 250 bool playback_mode = command_line.HasSwitch(switches::kPlaybackMode);
244 251
245 // Initialize context members. 252 // Initialize context members.
246 253
247 ApplyProfileParamsToContext(main_context); 254 ApplyProfileParamsToContext(main_context);
248 ApplyProfileParamsToContext(media_request_context_); 255 ApplyProfileParamsToContext(media_request_context_);
249 ApplyProfileParamsToContext(extensions_context); 256 ApplyProfileParamsToContext(extensions_context);
250 257
258 if (http_server_properties_manager_.get())
259 http_server_properties_manager_->InitializeOnIOThread();
260
251 main_context->set_transport_security_state(transport_security_state()); 261 main_context->set_transport_security_state(transport_security_state());
252 media_request_context_->set_transport_security_state( 262 media_request_context_->set_transport_security_state(
253 transport_security_state()); 263 transport_security_state());
254 extensions_context->set_transport_security_state(transport_security_state()); 264 extensions_context->set_transport_security_state(transport_security_state());
255 265
256 main_context->set_net_log(io_thread->net_log()); 266 main_context->set_net_log(io_thread->net_log());
257 media_request_context_->set_net_log(io_thread->net_log()); 267 media_request_context_->set_net_log(io_thread->net_log());
258 extensions_context->set_net_log(io_thread->net_log()); 268 extensions_context->set_net_log(io_thread->net_log());
259 269
260 main_context->set_network_delegate(network_delegate()); 270 main_context->set_network_delegate(network_delegate());
261 media_request_context_->set_network_delegate(network_delegate()); 271 media_request_context_->set_network_delegate(network_delegate());
262 272
273 main_context->set_http_server_properties(http_server_properties());
274 media_request_context_->set_http_server_properties(http_server_properties());
275
263 main_context->set_host_resolver( 276 main_context->set_host_resolver(
264 io_thread_globals->host_resolver.get()); 277 io_thread_globals->host_resolver.get());
265 media_request_context_->set_host_resolver( 278 media_request_context_->set_host_resolver(
266 io_thread_globals->host_resolver.get()); 279 io_thread_globals->host_resolver.get());
267 main_context->set_cert_verifier( 280 main_context->set_cert_verifier(
268 io_thread_globals->cert_verifier.get()); 281 io_thread_globals->cert_verifier.get());
269 media_request_context_->set_cert_verifier( 282 media_request_context_->set_cert_verifier(
270 io_thread_globals->cert_verifier.get()); 283 io_thread_globals->cert_verifier.get());
271 main_context->set_dnsrr_resolver( 284 main_context->set_dnsrr_resolver(
272 io_thread_globals->dnsrr_resolver.get()); 285 io_thread_globals->dnsrr_resolver.get());
(...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after
346 net::HttpCache* main_cache = new net::HttpCache( 359 net::HttpCache* main_cache = new net::HttpCache(
347 main_context->host_resolver(), 360 main_context->host_resolver(),
348 main_context->cert_verifier(), 361 main_context->cert_verifier(),
349 main_context->origin_bound_cert_service(), 362 main_context->origin_bound_cert_service(),
350 main_context->dnsrr_resolver(), 363 main_context->dnsrr_resolver(),
351 main_context->dns_cert_checker(), 364 main_context->dns_cert_checker(),
352 main_context->proxy_service(), 365 main_context->proxy_service(),
353 main_context->ssl_config_service(), 366 main_context->ssl_config_service(),
354 main_context->http_auth_handler_factory(), 367 main_context->http_auth_handler_factory(),
355 main_context->network_delegate(), 368 main_context->network_delegate(),
369 main_context->http_server_properties(),
356 main_context->net_log(), 370 main_context->net_log(),
357 main_backend); 371 main_backend);
358 372
359 net::HttpCache::DefaultBackend* media_backend = 373 net::HttpCache::DefaultBackend* media_backend =
360 new net::HttpCache::DefaultBackend( 374 new net::HttpCache::DefaultBackend(
361 net::MEDIA_CACHE, lazy_params_->media_cache_path, 375 net::MEDIA_CACHE, lazy_params_->media_cache_path,
362 lazy_params_->media_cache_max_size, 376 lazy_params_->media_cache_max_size,
363 BrowserThread::GetMessageLoopProxyForThread(BrowserThread::CACHE)); 377 BrowserThread::GetMessageLoopProxyForThread(BrowserThread::CACHE));
364 net::HttpNetworkSession* main_network_session = main_cache->GetSession(); 378 net::HttpNetworkSession* main_network_session = main_cache->GetSession();
365 net::HttpCache* media_cache = 379 net::HttpCache* media_cache =
(...skipping 18 matching lines...) Expand all
384 main_context->set_job_factory(job_factory()); 398 main_context->set_job_factory(job_factory());
385 media_request_context_->set_job_factory(job_factory()); 399 media_request_context_->set_job_factory(job_factory());
386 extensions_context->set_job_factory(job_factory()); 400 extensions_context->set_job_factory(job_factory());
387 401
388 job_factory()->AddInterceptor( 402 job_factory()->AddInterceptor(
389 new chrome_browser_net::ConnectInterceptor(predictor_.get())); 403 new chrome_browser_net::ConnectInterceptor(predictor_.get()));
390 404
391 lazy_params_.reset(); 405 lazy_params_.reset();
392 } 406 }
393 407
408 net::HttpServerProperties* ProfileImplIOData::http_server_properties() const {
409 return http_server_properties_manager_.get();
410 }
411
394 scoped_refptr<ChromeURLRequestContext> 412 scoped_refptr<ChromeURLRequestContext>
395 ProfileImplIOData::InitializeAppRequestContext( 413 ProfileImplIOData::InitializeAppRequestContext(
396 scoped_refptr<ChromeURLRequestContext> main_context, 414 scoped_refptr<ChromeURLRequestContext> main_context,
397 const std::string& app_id) const { 415 const std::string& app_id) const {
398 AppRequestContext* context = new AppRequestContext; 416 AppRequestContext* context = new AppRequestContext;
399 417
400 // Copy most state from the main context. 418 // Copy most state from the main context.
401 context->CopyFrom(main_context); 419 context->CopyFrom(main_context);
402 420
403 FilePath app_path = app_path_.AppendASCII(app_id); 421 FilePath app_path = app_path_.AppendASCII(app_id);
(...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after
462 scoped_refptr<ChromeURLRequestContext> 480 scoped_refptr<ChromeURLRequestContext>
463 ProfileImplIOData::AcquireIsolatedAppRequestContext( 481 ProfileImplIOData::AcquireIsolatedAppRequestContext(
464 scoped_refptr<ChromeURLRequestContext> main_context, 482 scoped_refptr<ChromeURLRequestContext> main_context,
465 const std::string& app_id) const { 483 const std::string& app_id) const {
466 // We create per-app contexts on demand, unlike the others above. 484 // We create per-app contexts on demand, unlike the others above.
467 scoped_refptr<ChromeURLRequestContext> app_request_context = 485 scoped_refptr<ChromeURLRequestContext> app_request_context =
468 InitializeAppRequestContext(main_context, app_id); 486 InitializeAppRequestContext(main_context, app_id);
469 DCHECK(app_request_context); 487 DCHECK(app_request_context);
470 return app_request_context; 488 return app_request_context;
471 } 489 }
OLDNEW
« no previous file with comments | « chrome/browser/profiles/profile_impl_io_data.h ('k') | chrome/chrome_browser.gypi » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698