OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "extensions/browser/mojo/service_registration.h" | 5 #include "extensions/browser/mojo/service_registration.h" |
6 | 6 |
7 #include <string> | 7 #include <string> |
8 | 8 |
9 #include "base/bind.h" | 9 #include "base/bind.h" |
10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
11 #include "content/public/browser/render_frame_host.h" | 11 #include "content/public/browser/render_frame_host.h" |
12 #include "content/public/browser/render_process_host.h" | 12 #include "content/public/browser/render_process_host.h" |
13 #include "content/public/browser/site_instance.h" | 13 #include "content/public/browser/site_instance.h" |
14 #include "content/public/common/service_registry.h" | 14 #include "content/public/common/service_registry.h" |
15 #include "extensions/browser/api/serial/serial_service_factory.h" | 15 #include "extensions/browser/api/serial/serial_service_factory.h" |
16 #include "extensions/browser/extension_registry.h" | 16 #include "extensions/browser/extension_registry.h" |
17 #include "extensions/browser/extensions_browser_client.h" | 17 #include "extensions/browser/extensions_browser_client.h" |
18 #include "extensions/browser/mojo/keep_alive_impl.h" | 18 #include "extensions/browser/mojo/keep_alive_impl.h" |
19 #include "extensions/browser/process_map.h" | 19 #include "extensions/browser/process_map.h" |
20 #include "extensions/common/constants.h" | 20 #include "extensions/common/constants.h" |
21 #include "extensions/common/extension_api.h" | 21 #include "extensions/common/extension_api.h" |
22 #include "extensions/common/switches.h" | 22 #include "extensions/common/switches.h" |
| 23 #include "services/shell/public/cpp/interface_registry.h" |
23 | 24 |
24 #if defined(ENABLE_WIFI_DISPLAY) | 25 #if defined(ENABLE_WIFI_DISPLAY) |
25 #include "extensions/browser/api/display_source/wifi_display/wifi_display_media_
service_impl.h" | 26 #include "extensions/browser/api/display_source/wifi_display/wifi_display_media_
service_impl.h" |
26 #include "extensions/browser/api/display_source/wifi_display/wifi_display_sessio
n_service_impl.h" | 27 #include "extensions/browser/api/display_source/wifi_display/wifi_display_sessio
n_service_impl.h" |
27 #endif | 28 #endif |
28 | 29 |
29 namespace extensions { | 30 namespace extensions { |
30 namespace { | 31 namespace { |
31 | 32 |
32 bool ExtensionHasPermission(const Extension* extension, | 33 bool ExtensionHasPermission(const Extension* extension, |
33 content::RenderProcessHost* render_process_host, | 34 content::RenderProcessHost* render_process_host, |
34 const std::string& permission_name) { | 35 const std::string& permission_name) { |
35 Feature::Context context = | 36 Feature::Context context = |
36 ProcessMap::Get(render_process_host->GetBrowserContext()) | 37 ProcessMap::Get(render_process_host->GetBrowserContext()) |
37 ->GetMostLikelyContextType(extension, render_process_host->GetID()); | 38 ->GetMostLikelyContextType(extension, render_process_host->GetID()); |
38 | 39 |
39 return ExtensionAPI::GetSharedInstance() | 40 return ExtensionAPI::GetSharedInstance() |
40 ->IsAvailable(permission_name, extension, context, extension->url()) | 41 ->IsAvailable(permission_name, extension, context, extension->url()) |
41 .is_available(); | 42 .is_available(); |
42 } | 43 } |
43 | 44 |
44 } // namespace | 45 } // namespace |
45 | 46 |
46 void RegisterServicesForFrame(content::RenderFrameHost* render_frame_host, | 47 void RegisterServicesForFrame(content::RenderFrameHost* render_frame_host, |
47 const Extension* extension) { | 48 const Extension* extension) { |
48 DCHECK(extension); | 49 DCHECK(extension); |
49 | 50 |
50 content::ServiceRegistry* service_registry = | 51 shell::InterfaceRegistry* registry = |
51 render_frame_host->GetServiceRegistry(); | 52 render_frame_host->GetInterfaceRegistry(); |
52 if (base::CommandLine::ForCurrentProcess()->HasSwitch( | 53 if (base::CommandLine::ForCurrentProcess()->HasSwitch( |
53 switches::kEnableMojoSerialService)) { | 54 switches::kEnableMojoSerialService)) { |
54 if (ExtensionHasPermission(extension, render_frame_host->GetProcess(), | 55 if (ExtensionHasPermission(extension, render_frame_host->GetProcess(), |
55 "serial")) { | 56 "serial")) { |
56 service_registry->AddService(base::Bind(&BindToSerialServiceRequest)); | 57 registry->AddInterface(base::Bind(&BindToSerialServiceRequest)); |
57 } | 58 } |
58 } | 59 } |
59 service_registry->AddService(base::Bind( | 60 registry->AddInterface(base::Bind( |
60 KeepAliveImpl::Create, | 61 KeepAliveImpl::Create, |
61 render_frame_host->GetProcess()->GetBrowserContext(), extension)); | 62 render_frame_host->GetProcess()->GetBrowserContext(), extension)); |
62 | 63 |
63 #if defined(ENABLE_WIFI_DISPLAY) | 64 #if defined(ENABLE_WIFI_DISPLAY) |
64 if (ExtensionHasPermission(extension, render_frame_host->GetProcess(), | 65 if (ExtensionHasPermission(extension, render_frame_host->GetProcess(), |
65 "displaySource")) { | 66 "displaySource")) { |
66 service_registry->AddService( | 67 registry->AddInterface( |
67 base::Bind(WiFiDisplaySessionServiceImpl::BindToRequest, | 68 base::Bind(WiFiDisplaySessionServiceImpl::BindToRequest, |
68 render_frame_host->GetProcess()->GetBrowserContext())); | 69 render_frame_host->GetProcess()->GetBrowserContext())); |
69 service_registry->AddService( | 70 registry->AddInterface( |
70 base::Bind(WiFiDisplayMediaServiceImpl::BindToRequest)); | 71 base::Bind(WiFiDisplayMediaServiceImpl::BindToRequest)); |
71 } | 72 } |
72 #endif | 73 #endif |
73 } | 74 } |
74 | 75 |
75 } // namespace extensions | 76 } // namespace extensions |
OLD | NEW |