OLD | NEW |
---|---|
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/sqlite_origin_bound_cert_store.h" | |
15 #include "chrome/browser/net/sqlite_persistent_cookie_store.h" | 16 #include "chrome/browser/net/sqlite_persistent_cookie_store.h" |
16 #include "chrome/browser/prefs/pref_member.h" | 17 #include "chrome/browser/prefs/pref_member.h" |
17 #include "chrome/browser/profiles/profile.h" | 18 #include "chrome/browser/profiles/profile.h" |
18 #include "chrome/common/chrome_constants.h" | 19 #include "chrome/common/chrome_constants.h" |
19 #include "chrome/common/chrome_switches.h" | 20 #include "chrome/common/chrome_switches.h" |
20 #include "chrome/common/pref_names.h" | 21 #include "chrome/common/pref_names.h" |
21 #include "chrome/common/url_constants.h" | 22 #include "chrome/common/url_constants.h" |
22 #include "content/browser/browser_thread.h" | 23 #include "content/browser/browser_thread.h" |
23 #include "content/browser/resource_context.h" | 24 #include "content/browser/resource_context.h" |
25 #include "net/base/origin_bound_cert_service.h" | |
24 #include "net/ftp/ftp_network_layer.h" | 26 #include "net/ftp/ftp_network_layer.h" |
25 #include "net/http/http_cache.h" | 27 #include "net/http/http_cache.h" |
26 | 28 |
27 ProfileImplIOData::Handle::Handle(Profile* profile) | 29 ProfileImplIOData::Handle::Handle(Profile* profile) |
28 : io_data_(new ProfileImplIOData), | 30 : io_data_(new ProfileImplIOData), |
29 profile_(profile), | 31 profile_(profile), |
30 initialized_(false) { | 32 initialized_(false) { |
31 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 33 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
32 DCHECK(profile); | 34 DCHECK(profile); |
33 } | 35 } |
(...skipping 11 matching lines...) Expand all Loading... | |
45 for (ChromeURLRequestContextGetterMap::iterator iter = | 47 for (ChromeURLRequestContextGetterMap::iterator iter = |
46 app_request_context_getter_map_.begin(); | 48 app_request_context_getter_map_.begin(); |
47 iter != app_request_context_getter_map_.end(); | 49 iter != app_request_context_getter_map_.end(); |
48 ++iter) { | 50 ++iter) { |
49 iter->second->CleanupOnUIThread(); | 51 iter->second->CleanupOnUIThread(); |
50 } | 52 } |
51 | 53 |
52 io_data_.release()->ShutdownOnUIThread(); | 54 io_data_.release()->ShutdownOnUIThread(); |
53 } | 55 } |
54 | 56 |
55 void ProfileImplIOData::Handle::Init(const FilePath& cookie_path, | 57 void ProfileImplIOData::Handle::Init( |
56 const FilePath& cache_path, | 58 const FilePath& cookie_path, |
57 int cache_max_size, | 59 const FilePath& origin_bound_cert_path, |
58 const FilePath& media_cache_path, | 60 const FilePath& cache_path, |
59 int media_cache_max_size, | 61 int cache_max_size, |
60 const FilePath& extensions_cookie_path, | 62 const FilePath& media_cache_path, |
61 const FilePath& app_path) { | 63 int media_cache_max_size, |
64 const FilePath& extensions_cookie_path, | |
65 const FilePath& extensions_origin_bound_cert_path, | |
66 const FilePath& app_path) { | |
62 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 67 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
63 DCHECK(!io_data_->lazy_params_.get()); | 68 DCHECK(!io_data_->lazy_params_.get()); |
64 LazyParams* lazy_params = new LazyParams; | 69 LazyParams* lazy_params = new LazyParams; |
65 | 70 |
66 lazy_params->cookie_path = cookie_path; | 71 lazy_params->cookie_path = cookie_path; |
72 lazy_params->origin_bound_cert_path = origin_bound_cert_path; | |
67 lazy_params->cache_path = cache_path; | 73 lazy_params->cache_path = cache_path; |
68 lazy_params->cache_max_size = cache_max_size; | 74 lazy_params->cache_max_size = cache_max_size; |
69 lazy_params->media_cache_path = media_cache_path; | 75 lazy_params->media_cache_path = media_cache_path; |
70 lazy_params->media_cache_max_size = media_cache_max_size; | 76 lazy_params->media_cache_max_size = media_cache_max_size; |
71 lazy_params->extensions_cookie_path = extensions_cookie_path; | 77 lazy_params->extensions_cookie_path = extensions_cookie_path; |
78 lazy_params->extensions_origin_bound_cert_path = | |
79 extensions_origin_bound_cert_path; | |
72 | 80 |
73 io_data_->lazy_params_.reset(lazy_params); | 81 io_data_->lazy_params_.reset(lazy_params); |
74 | 82 |
75 // Keep track of isolated app path separately so we can use it on demand. | 83 // Keep track of isolated app path separately so we can use it on demand. |
76 io_data_->app_path_ = app_path; | 84 io_data_->app_path_ = app_path; |
77 } | 85 } |
78 | 86 |
79 base::Callback<ChromeURLDataManagerBackend*(void)> | 87 base::Callback<ChromeURLDataManagerBackend*(void)> |
80 ProfileImplIOData::Handle::GetChromeURLDataManagerBackendGetter() const { | 88 ProfileImplIOData::Handle::GetChromeURLDataManagerBackendGetter() const { |
81 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 89 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
(...skipping 141 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
223 io_thread_globals->http_auth_handler_factory.get()); | 231 io_thread_globals->http_auth_handler_factory.get()); |
224 media_request_context_->set_http_auth_handler_factory( | 232 media_request_context_->set_http_auth_handler_factory( |
225 io_thread_globals->http_auth_handler_factory.get()); | 233 io_thread_globals->http_auth_handler_factory.get()); |
226 | 234 |
227 main_context->set_dns_cert_checker(dns_cert_checker()); | 235 main_context->set_dns_cert_checker(dns_cert_checker()); |
228 media_request_context_->set_dns_cert_checker(dns_cert_checker()); | 236 media_request_context_->set_dns_cert_checker(dns_cert_checker()); |
229 | 237 |
230 main_context->set_proxy_service(proxy_service()); | 238 main_context->set_proxy_service(proxy_service()); |
231 media_request_context_->set_proxy_service(proxy_service()); | 239 media_request_context_->set_proxy_service(proxy_service()); |
232 | 240 |
241 // BEGIN(rkn) | |
wtc
2011/08/01 18:21:24
Remove the "BEGIN(rkn)" and "END(rkn)" comments.
| |
242 scoped_refptr<net::OriginBoundCertService> origin_bound_cert_service = NULL; | |
243 if (record_mode || playback_mode) { | |
244 // Don't use existing cookies and use an in-memory store. | |
245 origin_bound_cert_service= new net::OriginBoundCertService( | |
246 new net::DefaultOriginBoundCertStore(NULL)); | |
247 } | |
248 | |
249 // Setup origin bound cert service. | |
250 if (!origin_bound_cert_service) { | |
251 DCHECK(!lazy_params_->origin_bound_cert_path.empty()); | |
252 | |
253 scoped_refptr<SQLiteOriginBoundCertStore> origin_bound_cert_db = | |
254 new SQLiteOriginBoundCertStore(lazy_params_->origin_bound_cert_path); | |
255 origin_bound_cert_db->SetClearLocalStateOnExit( | |
256 profile_params->clear_local_state_on_exit); | |
257 origin_bound_cert_service = | |
258 new net::OriginBoundCertService( | |
259 new net::DefaultOriginBoundCertStore(origin_bound_cert_db.get())); | |
260 } | |
261 | |
262 net::OriginBoundCertService* extensions_origin_bound_cert_service = | |
wtc
2011/08/01 18:21:24
Store this in a scoped_refptr. As a general rule,
| |
263 new net::OriginBoundCertService( | |
264 new net::DefaultOriginBoundCertStore( | |
265 new SQLiteOriginBoundCertStore( | |
266 lazy_params_->extensions_origin_bound_cert_path))); | |
267 | |
268 main_context->set_origin_bound_cert_service(origin_bound_cert_service); | |
269 media_request_context_->set_origin_bound_cert_service( | |
270 origin_bound_cert_service); | |
271 extensions_context->set_origin_bound_cert_service( | |
272 extensions_origin_bound_cert_service); | |
273 // END(rkn) | |
wtc
2011/08/01 18:21:24
Is it OK to put this code next to the code that se
| |
274 | |
233 net::HttpCache::DefaultBackend* main_backend = | 275 net::HttpCache::DefaultBackend* main_backend = |
234 new net::HttpCache::DefaultBackend( | 276 new net::HttpCache::DefaultBackend( |
235 net::DISK_CACHE, | 277 net::DISK_CACHE, |
236 lazy_params_->cache_path, | 278 lazy_params_->cache_path, |
237 lazy_params_->cache_max_size, | 279 lazy_params_->cache_max_size, |
238 BrowserThread::GetMessageLoopProxyForThread(BrowserThread::CACHE)); | 280 BrowserThread::GetMessageLoopProxyForThread(BrowserThread::CACHE)); |
239 net::HttpCache* main_cache = new net::HttpCache( | 281 net::HttpCache* main_cache = new net::HttpCache( |
240 main_context->host_resolver(), | 282 main_context->host_resolver(), |
241 main_context->cert_verifier(), | 283 main_context->cert_verifier(), |
284 main_context->origin_bound_cert_service(), | |
242 main_context->dnsrr_resolver(), | 285 main_context->dnsrr_resolver(), |
243 main_context->dns_cert_checker(), | 286 main_context->dns_cert_checker(), |
244 main_context->proxy_service(), | 287 main_context->proxy_service(), |
245 main_context->ssl_config_service(), | 288 main_context->ssl_config_service(), |
246 main_context->http_auth_handler_factory(), | 289 main_context->http_auth_handler_factory(), |
247 main_context->network_delegate(), | 290 main_context->network_delegate(), |
248 main_context->net_log(), | 291 main_context->net_log(), |
249 main_backend); | 292 main_backend); |
250 | 293 |
251 net::HttpCache::DefaultBackend* media_backend = | 294 net::HttpCache::DefaultBackend* media_backend = |
(...skipping 133 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
385 scoped_refptr<ProfileIOData::RequestContext> | 428 scoped_refptr<ProfileIOData::RequestContext> |
386 ProfileImplIOData::AcquireIsolatedAppRequestContext( | 429 ProfileImplIOData::AcquireIsolatedAppRequestContext( |
387 scoped_refptr<ChromeURLRequestContext> main_context, | 430 scoped_refptr<ChromeURLRequestContext> main_context, |
388 const std::string& app_id) const { | 431 const std::string& app_id) const { |
389 // We create per-app contexts on demand, unlike the others above. | 432 // We create per-app contexts on demand, unlike the others above. |
390 scoped_refptr<RequestContext> app_request_context = | 433 scoped_refptr<RequestContext> app_request_context = |
391 InitializeAppRequestContext(main_context, app_id); | 434 InitializeAppRequestContext(main_context, app_id); |
392 DCHECK(app_request_context); | 435 DCHECK(app_request_context); |
393 return app_request_context; | 436 return app_request_context; |
394 } | 437 } |
OLD | NEW |