OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/chrome_content_browser_client.h" | 5 #include "chrome/browser/chrome_content_browser_client.h" |
6 | 6 |
7 #include <map> | 7 #include <map> |
8 #include <set> | 8 #include <set> |
9 #include <utility> | 9 #include <utility> |
10 #include <vector> | 10 #include <vector> |
11 | 11 |
12 #include "base/base_switches.h" | 12 #include "base/base_switches.h" |
13 #include "base/bind.h" | 13 #include "base/bind.h" |
14 #include "base/bind_helpers.h" | 14 #include "base/bind_helpers.h" |
15 #include "base/command_line.h" | 15 #include "base/command_line.h" |
16 #include "base/files/scoped_file.h" | 16 #include "base/files/scoped_file.h" |
17 #include "base/i18n/character_encoding.h" | 17 #include "base/i18n/character_encoding.h" |
18 #include "base/json/json_reader.h" | 18 #include "base/json/json_reader.h" |
19 #include "base/lazy_instance.h" | 19 #include "base/lazy_instance.h" |
20 #include "base/macros.h" | 20 #include "base/macros.h" |
21 #include "base/memory/ptr_util.h" | 21 #include "base/memory/ptr_util.h" |
| 22 #include "base/metrics/field_trial_params.h" |
22 #include "base/metrics/histogram_macros.h" | 23 #include "base/metrics/histogram_macros.h" |
23 #include "base/path_service.h" | 24 #include "base/path_service.h" |
24 #include "base/strings/string_number_conversions.h" | 25 #include "base/strings/string_number_conversions.h" |
25 #include "base/strings/string_split.h" | 26 #include "base/strings/string_split.h" |
26 #include "base/strings/string_util.h" | 27 #include "base/strings/string_util.h" |
27 #include "base/strings/stringprintf.h" | 28 #include "base/strings/stringprintf.h" |
28 #include "base/strings/utf_string_conversions.h" | 29 #include "base/strings/utf_string_conversions.h" |
29 #include "base/threading/sequenced_worker_pool.h" | 30 #include "base/threading/sequenced_worker_pool.h" |
30 #include "base/threading/thread_task_runner_handle.h" | 31 #include "base/threading/thread_task_runner_handle.h" |
31 #include "build/build_config.h" | 32 #include "build/build_config.h" |
(...skipping 16 matching lines...) Expand all Loading... |
48 #include "chrome/browser/font_family_cache.h" | 49 #include "chrome/browser/font_family_cache.h" |
49 #include "chrome/browser/media/router/media_router_feature.h" | 50 #include "chrome/browser/media/router/media_router_feature.h" |
50 #include "chrome/browser/media/router/presentation_service_delegate_impl.h" | 51 #include "chrome/browser/media/router/presentation_service_delegate_impl.h" |
51 #include "chrome/browser/media/router/receiver_presentation_service_delegate_imp
l.h" | 52 #include "chrome/browser/media/router/receiver_presentation_service_delegate_imp
l.h" |
52 #include "chrome/browser/media/webrtc/media_capture_devices_dispatcher.h" | 53 #include "chrome/browser/media/webrtc/media_capture_devices_dispatcher.h" |
53 #include "chrome/browser/memory/chrome_memory_coordinator_delegate.h" | 54 #include "chrome/browser/memory/chrome_memory_coordinator_delegate.h" |
54 #include "chrome/browser/metrics/chrome_browser_main_extra_parts_metrics.h" | 55 #include "chrome/browser/metrics/chrome_browser_main_extra_parts_metrics.h" |
55 #include "chrome/browser/nacl_host/nacl_browser_delegate_impl.h" | 56 #include "chrome/browser/nacl_host/nacl_browser_delegate_impl.h" |
56 #include "chrome/browser/net_benchmarking.h" | 57 #include "chrome/browser/net_benchmarking.h" |
57 #include "chrome/browser/notifications/platform_notification_service_impl.h" | 58 #include "chrome/browser/notifications/platform_notification_service_impl.h" |
| 59 #include "chrome/browser/page_load_metrics/ads_detection.h" |
58 #include "chrome/browser/page_load_metrics/experiments/delay_navigation_throttle
.h" | 60 #include "chrome/browser/page_load_metrics/experiments/delay_navigation_throttle
.h" |
59 #include "chrome/browser/page_load_metrics/metrics_navigation_throttle.h" | 61 #include "chrome/browser/page_load_metrics/metrics_navigation_throttle.h" |
60 #include "chrome/browser/page_load_metrics/page_load_metrics_util.h" | 62 #include "chrome/browser/page_load_metrics/page_load_metrics_util.h" |
61 #include "chrome/browser/password_manager/chrome_password_manager_client.h" | 63 #include "chrome/browser/password_manager/chrome_password_manager_client.h" |
62 #include "chrome/browser/permissions/permission_context_base.h" | 64 #include "chrome/browser/permissions/permission_context_base.h" |
63 #include "chrome/browser/platform_util.h" | 65 #include "chrome/browser/platform_util.h" |
64 #include "chrome/browser/prerender/prerender_final_status.h" | 66 #include "chrome/browser/prerender/prerender_final_status.h" |
65 #include "chrome/browser/prerender/prerender_manager.h" | 67 #include "chrome/browser/prerender/prerender_manager.h" |
66 #include "chrome/browser/prerender/prerender_manager_factory.h" | 68 #include "chrome/browser/prerender/prerender_manager_factory.h" |
67 #include "chrome/browser/prerender/prerender_message_filter.h" | 69 #include "chrome/browser/prerender/prerender_message_filter.h" |
(...skipping 1188 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1256 *is_renderer_initiated = false; | 1258 *is_renderer_initiated = false; |
1257 *referrer = content::Referrer(); | 1259 *referrer = content::Referrer(); |
1258 } | 1260 } |
1259 | 1261 |
1260 #if BUILDFLAG(ENABLE_EXTENSIONS) | 1262 #if BUILDFLAG(ENABLE_EXTENSIONS) |
1261 ChromeContentBrowserClientExtensionsPart::OverrideNavigationParams( | 1263 ChromeContentBrowserClientExtensionsPart::OverrideNavigationParams( |
1262 site_instance, transition, is_renderer_initiated, referrer); | 1264 site_instance, transition, is_renderer_initiated, referrer); |
1263 #endif | 1265 #endif |
1264 } | 1266 } |
1265 | 1267 |
1266 bool ChromeContentBrowserClient:: | 1268 bool ChromeContentBrowserClient::ShouldIsolateFrameForTopDocumentIsolation( |
1267 ShouldFrameShareParentSiteInstanceDespiteTopDocumentIsolation( | 1269 content::NavigationHandle* navigation_handle, |
1268 const GURL& url, | 1270 content::SiteInstance* main_frame_site_instance) { |
1269 content::SiteInstance* parent_site_instance) { | 1271 if (IsNTPSiteInstance(main_frame_site_instance)) |
1270 if (IsNTPSiteInstance(parent_site_instance)) | 1272 return false; |
1271 return true; | |
1272 | 1273 |
1273 #if BUILDFLAG(ENABLE_EXTENSIONS) | 1274 #if BUILDFLAG(ENABLE_EXTENSIONS) |
1274 return ChromeContentBrowserClientExtensionsPart:: | 1275 if (ChromeContentBrowserClientExtensionsPart:: |
1275 ShouldFrameShareParentSiteInstanceDespiteTopDocumentIsolation( | 1276 IsMainFrameSiteInstanceExcludedFromTopDocumentIsolation( |
1276 url, parent_site_instance); | 1277 main_frame_site_instance)) { |
1277 #else | 1278 return false; |
| 1279 } |
| 1280 #endif |
| 1281 |
| 1282 features::TopDocumentIsolationMode tdiMode = |
| 1283 static_cast<features::TopDocumentIsolationMode>( |
| 1284 base::GetFieldTrialParamByFeatureAsInt( |
| 1285 ::features::kTopDocumentIsolation, |
| 1286 ::features::kTopDocumentIsolationModeParam, |
| 1287 static_cast<int>( |
| 1288 features::TopDocumentIsolationMode::Unspecified))); |
| 1289 switch (tdiMode) { |
| 1290 case features::TopDocumentIsolationMode::Unspecified: |
| 1291 case features::TopDocumentIsolationMode::Ads: |
| 1292 return page_load_metrics::GetDetectedAdTypes(navigation_handle).any(); |
| 1293 |
| 1294 case features::TopDocumentIsolationMode::CrossSite: |
| 1295 return true; |
| 1296 } |
| 1297 NOTREACHED(); |
1278 return false; | 1298 return false; |
1279 #endif | |
1280 } | 1299 } |
1281 | 1300 |
1282 bool ChromeContentBrowserClient::IsSuitableHost( | 1301 bool ChromeContentBrowserClient::IsSuitableHost( |
1283 content::RenderProcessHost* process_host, | 1302 content::RenderProcessHost* process_host, |
1284 const GURL& site_url) { | 1303 const GURL& site_url) { |
1285 Profile* profile = | 1304 Profile* profile = |
1286 Profile::FromBrowserContext(process_host->GetBrowserContext()); | 1305 Profile::FromBrowserContext(process_host->GetBrowserContext()); |
1287 // This may be NULL during tests. In that case, just assume any site can | 1306 // This may be NULL during tests. In that case, just assume any site can |
1288 // share any host. | 1307 // share any host. |
1289 if (!profile) | 1308 if (!profile) |
(...skipping 2159 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3449 // |safe_browsing_service_| may be unavailable in tests. | 3468 // |safe_browsing_service_| may be unavailable in tests. |
3450 if (safe_browsing_service_ && !safe_browsing_url_checker_delegate_) { | 3469 if (safe_browsing_service_ && !safe_browsing_url_checker_delegate_) { |
3451 safe_browsing_url_checker_delegate_ = | 3470 safe_browsing_url_checker_delegate_ = |
3452 new safe_browsing::UrlCheckerDelegateImpl( | 3471 new safe_browsing::UrlCheckerDelegateImpl( |
3453 safe_browsing_service_->database_manager(), | 3472 safe_browsing_service_->database_manager(), |
3454 safe_browsing_service_->ui_manager()); | 3473 safe_browsing_service_->ui_manager()); |
3455 } | 3474 } |
3456 | 3475 |
3457 return safe_browsing_url_checker_delegate_.get(); | 3476 return safe_browsing_url_checker_delegate_.get(); |
3458 } | 3477 } |
OLD | NEW |