| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "content/browser/frame_host/render_frame_host_impl.h" | 5 #include "content/browser/frame_host/render_frame_host_impl.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
| (...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 74 #include "content/public/common/browser_side_navigation_policy.h" | 74 #include "content/public/common/browser_side_navigation_policy.h" |
| 75 #include "content/public/common/content_constants.h" | 75 #include "content/public/common/content_constants.h" |
| 76 #include "content/public/common/content_switches.h" | 76 #include "content/public/common/content_switches.h" |
| 77 #include "content/public/common/file_chooser_file_info.h" | 77 #include "content/public/common/file_chooser_file_info.h" |
| 78 #include "content/public/common/file_chooser_params.h" | 78 #include "content/public/common/file_chooser_params.h" |
| 79 #include "content/public/common/isolated_world_ids.h" | 79 #include "content/public/common/isolated_world_ids.h" |
| 80 #include "content/public/common/url_constants.h" | 80 #include "content/public/common/url_constants.h" |
| 81 #include "content/public/common/url_utils.h" | 81 #include "content/public/common/url_utils.h" |
| 82 #include "device/geolocation/geolocation_service_context.h" | 82 #include "device/geolocation/geolocation_service_context.h" |
| 83 #include "device/vibration/vibration_manager_impl.h" | 83 #include "device/vibration/vibration_manager_impl.h" |
| 84 #include "media/mojo/interfaces/service_factory.mojom.h" |
| 84 #include "services/shell/public/cpp/connector.h" | 85 #include "services/shell/public/cpp/connector.h" |
| 85 #include "services/shell/public/cpp/interface_provider.h" | 86 #include "services/shell/public/cpp/interface_provider.h" |
| 86 #include "ui/accessibility/ax_tree.h" | 87 #include "ui/accessibility/ax_tree.h" |
| 87 #include "ui/accessibility/ax_tree_update.h" | 88 #include "ui/accessibility/ax_tree_update.h" |
| 88 #include "ui/gfx/geometry/quad_f.h" | 89 #include "ui/gfx/geometry/quad_f.h" |
| 89 #include "url/gurl.h" | 90 #include "url/gurl.h" |
| 90 | 91 |
| 91 // media::mojom::ServiceFactory is generated in GN builds only. | |
| 92 #if defined(MOJO_SHELL_CLIENT) | |
| 93 #include "media/mojo/interfaces/service_factory.mojom.h" | |
| 94 #endif | |
| 95 | |
| 96 #if defined(OS_ANDROID) | 92 #if defined(OS_ANDROID) |
| 97 #include "content/browser/mojo/interface_registrar_android.h" | 93 #include "content/browser/mojo/interface_registrar_android.h" |
| 98 #if defined(ENABLE_MOJO_CDM) | 94 #if defined(ENABLE_MOJO_CDM) |
| 99 #include "content/browser/media/android/provision_fetcher_impl.h" | 95 #include "content/browser/media/android/provision_fetcher_impl.h" |
| 100 #endif | 96 #endif |
| 101 #endif | 97 #endif |
| 102 | 98 |
| 103 #if defined(OS_MACOSX) | 99 #if defined(OS_MACOSX) |
| 104 #include "content/browser/frame_host/popup_menu_helper_mac.h" | 100 #include "content/browser/frame_host/popup_menu_helper_mac.h" |
| 105 #endif | 101 #endif |
| (...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 173 const std::vector<base::FilePath>& file_paths) { | 169 const std::vector<base::FilePath>& file_paths) { |
| 174 ChildProcessSecurityPolicyImpl* policy = | 170 ChildProcessSecurityPolicyImpl* policy = |
| 175 ChildProcessSecurityPolicyImpl::GetInstance(); | 171 ChildProcessSecurityPolicyImpl::GetInstance(); |
| 176 | 172 |
| 177 for (const auto& file : file_paths) { | 173 for (const auto& file : file_paths) { |
| 178 if (!policy->CanReadFile(child_id, file)) | 174 if (!policy->CanReadFile(child_id, file)) |
| 179 policy->GrantReadFile(child_id, file); | 175 policy->GrantReadFile(child_id, file); |
| 180 } | 176 } |
| 181 } | 177 } |
| 182 | 178 |
| 183 #if defined(MOJO_SHELL_CLIENT) | |
| 184 // media::mojom::ServiceFactory is generated in GN builds only. | 179 // media::mojom::ServiceFactory is generated in GN builds only. |
| 185 void CreateMediaServiceFactory( | 180 void CreateMediaServiceFactory( |
| 186 BrowserContext* browser_context, | 181 BrowserContext* browser_context, |
| 187 RenderFrameHost* render_frame_host, | 182 RenderFrameHost* render_frame_host, |
| 188 media::mojom::ServiceFactoryRequest request) { | 183 media::mojom::ServiceFactoryRequest request) { |
| 189 shell::Connector* connector = | 184 shell::Connector* connector = |
| 190 BrowserContext::GetShellConnectorFor(browser_context); | 185 BrowserContext::GetShellConnectorFor(browser_context); |
| 191 std::unique_ptr<shell::Connection> connection = | 186 std::unique_ptr<shell::Connection> connection = |
| 192 connector->Connect("mojo:media"); | 187 connector->Connect("mojo:media"); |
| 193 #if defined(OS_ANDROID) && defined(ENABLE_MOJO_CDM) | 188 #if defined(OS_ANDROID) && defined(ENABLE_MOJO_CDM) |
| 194 connection->GetInterfaceRegistry()->AddInterface( | 189 connection->GetInterfaceRegistry()->AddInterface( |
| 195 base::Bind(&ProvisionFetcherImpl::Create, this)); | 190 base::Bind(&ProvisionFetcherImpl::Create, render_frame_host)); |
| 196 #endif | 191 #endif |
| 197 GetContentClient()->browser()->ExposeInterfacesToMediaService( | 192 GetContentClient()->browser()->ExposeInterfacesToMediaService( |
| 198 connection->GetInterfaceRegistry(), render_frame_host); | 193 connection->GetInterfaceRegistry(), render_frame_host); |
| 199 connection->GetInterface(std::move(request)); | 194 connection->GetInterface(std::move(request)); |
| 200 } | 195 } |
| 201 #endif // defined(MOJO_SHELL_CLIENT) | |
| 202 | 196 |
| 203 } // namespace | 197 } // namespace |
| 204 | 198 |
| 205 // static | 199 // static |
| 206 RenderFrameHost* RenderFrameHost::FromID(int render_process_id, | 200 RenderFrameHost* RenderFrameHost::FromID(int render_process_id, |
| 207 int render_frame_id) { | 201 int render_frame_id) { |
| 208 return RenderFrameHostImpl::FromID(render_process_id, render_frame_id); | 202 return RenderFrameHostImpl::FromID(render_process_id, render_frame_id); |
| 209 } | 203 } |
| 210 | 204 |
| 211 #if defined(OS_ANDROID) | 205 #if defined(OS_ANDROID) |
| (...skipping 1890 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2102 #if defined(OS_CHROMEOS) || defined(OS_ANDROID) || defined(OS_MACOSX) | 2096 #if defined(OS_CHROMEOS) || defined(OS_ANDROID) || defined(OS_MACOSX) |
| 2103 enable_web_bluetooth = true; | 2097 enable_web_bluetooth = true; |
| 2104 #endif | 2098 #endif |
| 2105 | 2099 |
| 2106 if (enable_web_bluetooth) { | 2100 if (enable_web_bluetooth) { |
| 2107 GetInterfaceRegistry()->AddInterface(base::Bind( | 2101 GetInterfaceRegistry()->AddInterface(base::Bind( |
| 2108 base::IgnoreResult(&RenderFrameHostImpl::CreateWebBluetoothService), | 2102 base::IgnoreResult(&RenderFrameHostImpl::CreateWebBluetoothService), |
| 2109 base::Unretained(this))); | 2103 base::Unretained(this))); |
| 2110 } | 2104 } |
| 2111 | 2105 |
| 2112 #if defined(MOJO_SHELL_CLIENT) | |
| 2113 // media::mojom::ServiceFactory is generated in GN builds only. | |
| 2114 GetInterfaceRegistry()->AddInterface<media::mojom::ServiceFactory>( | 2106 GetInterfaceRegistry()->AddInterface<media::mojom::ServiceFactory>( |
| 2115 base::Bind(&CreateMediaServiceFactory, | 2107 base::Bind(&CreateMediaServiceFactory, |
| 2116 GetProcess()->GetBrowserContext(), this)); | 2108 GetProcess()->GetBrowserContext(), this)); |
| 2117 #endif // defined(MOJO_SHELL_CLIENT) | |
| 2118 | 2109 |
| 2119 #if defined(ENABLE_WEBVR) | 2110 #if defined(ENABLE_WEBVR) |
| 2120 const base::CommandLine& browser_command_line = | 2111 const base::CommandLine& browser_command_line = |
| 2121 *base::CommandLine::ForCurrentProcess(); | 2112 *base::CommandLine::ForCurrentProcess(); |
| 2122 | 2113 |
| 2123 if (browser_command_line.HasSwitch(switches::kEnableWebVR)) { | 2114 if (browser_command_line.HasSwitch(switches::kEnableWebVR)) { |
| 2124 GetInterfaceRegistry()->AddInterface<device::VRService>( | 2115 GetInterfaceRegistry()->AddInterface<device::VRService>( |
| 2125 base::Bind(&device::VRServiceImpl::BindRequest)); | 2116 base::Bind(&device::VRServiceImpl::BindRequest)); |
| 2126 } | 2117 } |
| 2127 #endif | 2118 #endif |
| (...skipping 901 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3029 web_bluetooth_service_->SetClientConnectionErrorHandler(base::Bind( | 3020 web_bluetooth_service_->SetClientConnectionErrorHandler(base::Bind( |
| 3030 &RenderFrameHostImpl::DeleteWebBluetoothService, base::Unretained(this))); | 3021 &RenderFrameHostImpl::DeleteWebBluetoothService, base::Unretained(this))); |
| 3031 return web_bluetooth_service_.get(); | 3022 return web_bluetooth_service_.get(); |
| 3032 } | 3023 } |
| 3033 | 3024 |
| 3034 void RenderFrameHostImpl::DeleteWebBluetoothService() { | 3025 void RenderFrameHostImpl::DeleteWebBluetoothService() { |
| 3035 web_bluetooth_service_.reset(); | 3026 web_bluetooth_service_.reset(); |
| 3036 } | 3027 } |
| 3037 | 3028 |
| 3038 } // namespace content | 3029 } // namespace content |
| OLD | NEW |