| 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> |
| (...skipping 136 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 147 #include "content/public/browser/resource_context.h" | 147 #include "content/public/browser/resource_context.h" |
| 148 #include "content/public/browser/site_instance.h" | 148 #include "content/public/browser/site_instance.h" |
| 149 #include "content/public/browser/web_contents.h" | 149 #include "content/public/browser/web_contents.h" |
| 150 #include "content/public/common/child_process_host.h" | 150 #include "content/public/common/child_process_host.h" |
| 151 #include "content/public/common/content_descriptors.h" | 151 #include "content/public/common/content_descriptors.h" |
| 152 #include "content/public/common/content_switches.h" | 152 #include "content/public/common/content_switches.h" |
| 153 #include "content/public/common/sandbox_type.h" | 153 #include "content/public/common/sandbox_type.h" |
| 154 #include "content/public/common/service_registry.h" | 154 #include "content/public/common/service_registry.h" |
| 155 #include "content/public/common/url_utils.h" | 155 #include "content/public/common/url_utils.h" |
| 156 #include "content/public/common/web_preferences.h" | 156 #include "content/public/common/web_preferences.h" |
| 157 #include "device/usb/public/interfaces/chooser_service.mojom.h" |
| 157 #include "device/usb/public/interfaces/device_manager.mojom.h" | 158 #include "device/usb/public/interfaces/device_manager.mojom.h" |
| 158 #include "gin/v8_initializer.h" | 159 #include "gin/v8_initializer.h" |
| 159 #include "mojo/shell/public/cpp/shell_client.h" | 160 #include "mojo/shell/public/cpp/shell_client.h" |
| 160 #include "net/base/mime_util.h" | 161 #include "net/base/mime_util.h" |
| 161 #include "net/cookies/canonical_cookie.h" | 162 #include "net/cookies/canonical_cookie.h" |
| 162 #include "net/cookies/cookie_options.h" | 163 #include "net/cookies/cookie_options.h" |
| 163 #include "net/ssl/ssl_cert_request_info.h" | 164 #include "net/ssl/ssl_cert_request_info.h" |
| 164 #include "ppapi/host/ppapi_host.h" | 165 #include "ppapi/host/ppapi_host.h" |
| 165 #include "storage/browser/fileapi/external_mount_points.h" | 166 #include "storage/browser/fileapi/external_mount_points.h" |
| 166 #include "ui/base/l10n/l10n_util.h" | 167 #include "ui/base/l10n/l10n_util.h" |
| (...skipping 119 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 286 | 287 |
| 287 #if defined(ENABLE_WEBRTC) | 288 #if defined(ENABLE_WEBRTC) |
| 288 #include "chrome/browser/media/webrtc_logging_handler_host.h" | 289 #include "chrome/browser/media/webrtc_logging_handler_host.h" |
| 289 #endif | 290 #endif |
| 290 | 291 |
| 291 #if defined(ENABLE_MEDIA_ROUTER) | 292 #if defined(ENABLE_MEDIA_ROUTER) |
| 292 #include "chrome/browser/media/router/media_router_feature.h" | 293 #include "chrome/browser/media/router/media_router_feature.h" |
| 293 #include "chrome/browser/media/router/presentation_service_delegate_impl.h" | 294 #include "chrome/browser/media/router/presentation_service_delegate_impl.h" |
| 294 #endif | 295 #endif |
| 295 | 296 |
| 296 #if !defined(OS_ANDROID) | |
| 297 #include "device/usb/public/interfaces/chooser_service.mojom.h" | |
| 298 #endif | |
| 299 | |
| 300 #if defined(ENABLE_WAYLAND_SERVER) | 297 #if defined(ENABLE_WAYLAND_SERVER) |
| 301 #include "chrome/browser/chrome_browser_main_extra_parts_exo.h" | 298 #include "chrome/browser/chrome_browser_main_extra_parts_exo.h" |
| 302 #endif | 299 #endif |
| 303 | 300 |
| 304 #if defined(ENABLE_MOJO_MEDIA) | 301 #if defined(ENABLE_MOJO_MEDIA) |
| 305 #include "chrome/browser/media/output_protection_impl.h" | 302 #include "chrome/browser/media/output_protection_impl.h" |
| 306 #endif | 303 #endif |
| 307 | 304 |
| 308 #if defined(ENABLE_MOJO_MEDIA_IN_BROWSER_PROCESS) | 305 #if defined(ENABLE_MOJO_MEDIA_IN_BROWSER_PROCESS) |
| 309 #include "media/mojo/services/mojo_media_application_factory.h" | 306 #include "media/mojo/services/mojo_media_application_factory.h" |
| (...skipping 376 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 686 if (!web_contents) { | 683 if (!web_contents) { |
| 687 NOTREACHED(); | 684 NOTREACHED(); |
| 688 return; | 685 return; |
| 689 } | 686 } |
| 690 | 687 |
| 691 UsbTabHelper* tab_helper = | 688 UsbTabHelper* tab_helper = |
| 692 UsbTabHelper::GetOrCreateForWebContents(web_contents); | 689 UsbTabHelper::GetOrCreateForWebContents(web_contents); |
| 693 tab_helper->CreateDeviceManager(render_frame_host, std::move(request)); | 690 tab_helper->CreateDeviceManager(render_frame_host, std::move(request)); |
| 694 } | 691 } |
| 695 | 692 |
| 696 #if !defined(OS_ANDROID) | |
| 697 void CreateWebUsbChooserService( | 693 void CreateWebUsbChooserService( |
| 698 RenderFrameHost* render_frame_host, | 694 RenderFrameHost* render_frame_host, |
| 699 mojo::InterfaceRequest<device::usb::ChooserService> request) { | 695 mojo::InterfaceRequest<device::usb::ChooserService> request) { |
| 700 WebContents* web_contents = | 696 WebContents* web_contents = |
| 701 WebContents::FromRenderFrameHost(render_frame_host); | 697 WebContents::FromRenderFrameHost(render_frame_host); |
| 702 if (!web_contents) { | 698 if (!web_contents) { |
| 703 NOTREACHED(); | 699 NOTREACHED(); |
| 704 return; | 700 return; |
| 705 } | 701 } |
| 706 | 702 |
| 707 UsbTabHelper* tab_helper = | 703 UsbTabHelper* tab_helper = |
| 708 UsbTabHelper::GetOrCreateForWebContents(web_contents); | 704 UsbTabHelper::GetOrCreateForWebContents(web_contents); |
| 709 tab_helper->CreateChooserService(render_frame_host, std::move(request)); | 705 tab_helper->CreateChooserService(render_frame_host, std::move(request)); |
| 710 } | 706 } |
| 711 #endif // !defined(OS_ANDROID) | |
| 712 | 707 |
| 713 bool GetDataSaverEnabledPref(const PrefService* prefs) { | 708 bool GetDataSaverEnabledPref(const PrefService* prefs) { |
| 714 // Enable data saver only when data saver pref is enabled and not part of | 709 // Enable data saver only when data saver pref is enabled and not part of |
| 715 // "Disabled" group of "SaveDataHeader" experiment. | 710 // "Disabled" group of "SaveDataHeader" experiment. |
| 716 return prefs->GetBoolean(prefs::kDataSaverEnabled) && | 711 return prefs->GetBoolean(prefs::kDataSaverEnabled) && |
| 717 base::FieldTrialList::FindFullName("SaveDataHeader") | 712 base::FieldTrialList::FindFullName("SaveDataHeader") |
| 718 .compare("Disabled"); | 713 .compare("Disabled"); |
| 719 } | 714 } |
| 720 | 715 |
| 721 } // namespace | 716 } // namespace |
| (...skipping 2072 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2794 #if defined(ENABLE_MOJO_MEDIA) | 2789 #if defined(ENABLE_MOJO_MEDIA) |
| 2795 registry->AddService( | 2790 registry->AddService( |
| 2796 base::Bind(&OutputProtectionImpl::Create, render_frame_host)); | 2791 base::Bind(&OutputProtectionImpl::Create, render_frame_host)); |
| 2797 #endif // defined(ENABLE_MOJO_MEDIA) | 2792 #endif // defined(ENABLE_MOJO_MEDIA) |
| 2798 } | 2793 } |
| 2799 | 2794 |
| 2800 void ChromeContentBrowserClient::RegisterRenderFrameMojoServices( | 2795 void ChromeContentBrowserClient::RegisterRenderFrameMojoServices( |
| 2801 content::ServiceRegistry* registry, | 2796 content::ServiceRegistry* registry, |
| 2802 content::RenderFrameHost* render_frame_host) { | 2797 content::RenderFrameHost* render_frame_host) { |
| 2803 registry->AddService(base::Bind(&CreateUsbDeviceManager, render_frame_host)); | 2798 registry->AddService(base::Bind(&CreateUsbDeviceManager, render_frame_host)); |
| 2804 #if !defined(OS_ANDROID) | |
| 2805 registry->AddService( | 2799 registry->AddService( |
| 2806 base::Bind(&CreateWebUsbChooserService, render_frame_host)); | 2800 base::Bind(&CreateWebUsbChooserService, render_frame_host)); |
| 2807 #endif // !defined(OS_ANDROID) | |
| 2808 } | 2801 } |
| 2809 | 2802 |
| 2810 void ChromeContentBrowserClient::RegisterInProcessMojoApplications( | 2803 void ChromeContentBrowserClient::RegisterInProcessMojoApplications( |
| 2811 StaticMojoApplicationMap* apps) { | 2804 StaticMojoApplicationMap* apps) { |
| 2812 #if (ENABLE_MOJO_MEDIA_IN_BROWSER_PROCESS) | 2805 #if (ENABLE_MOJO_MEDIA_IN_BROWSER_PROCESS) |
| 2813 apps->insert(std::make_pair("mojo:media", | 2806 apps->insert(std::make_pair("mojo:media", |
| 2814 base::Bind(&media::CreateMojoMediaApplication))); | 2807 base::Bind(&media::CreateMojoMediaApplication))); |
| 2815 #endif | 2808 #endif |
| 2816 } | 2809 } |
| 2817 | 2810 |
| (...skipping 161 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2979 if (channel <= kMaxDisableEncryptionChannel) { | 2972 if (channel <= kMaxDisableEncryptionChannel) { |
| 2980 static const char* const kWebRtcDevSwitchNames[] = { | 2973 static const char* const kWebRtcDevSwitchNames[] = { |
| 2981 switches::kDisableWebRtcEncryption, | 2974 switches::kDisableWebRtcEncryption, |
| 2982 }; | 2975 }; |
| 2983 to_command_line->CopySwitchesFrom(from_command_line, | 2976 to_command_line->CopySwitchesFrom(from_command_line, |
| 2984 kWebRtcDevSwitchNames, | 2977 kWebRtcDevSwitchNames, |
| 2985 arraysize(kWebRtcDevSwitchNames)); | 2978 arraysize(kWebRtcDevSwitchNames)); |
| 2986 } | 2979 } |
| 2987 } | 2980 } |
| 2988 #endif // defined(ENABLE_WEBRTC) | 2981 #endif // defined(ENABLE_WEBRTC) |
| OLD | NEW |