| 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 |