OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 // This class responds to requests from renderers for the list of plugins, and | 5 // This class responds to requests from renderers for the list of plugins, and |
6 // also a proxy object for plugin instances. | 6 // also a proxy object for plugin instances. |
7 | 7 |
8 #ifndef CONTENT_BROWSER_PLUGIN_SERVICE_H_ | 8 #ifndef CONTENT_BROWSER_PLUGIN_SERVICE_H_ |
9 #define CONTENT_BROWSER_PLUGIN_SERVICE_H_ | 9 #define CONTENT_BROWSER_PLUGIN_SERVICE_H_ |
10 #pragma once | 10 #pragma once |
11 | 11 |
12 #include <string> | 12 #include <string> |
13 #include <vector> | 13 #include <vector> |
14 | 14 |
15 #include "base/basictypes.h" | 15 #include "base/basictypes.h" |
16 #include "base/file_path.h" | |
17 #include "base/hash_tables.h" | |
18 #include "base/memory/scoped_vector.h" | 16 #include "base/memory/scoped_vector.h" |
19 #include "base/memory/singleton.h" | 17 #include "base/memory/singleton.h" |
20 #include "base/synchronization/lock.h" | |
21 #include "base/synchronization/waitable_event_watcher.h" | 18 #include "base/synchronization/waitable_event_watcher.h" |
22 #include "build/build_config.h" | 19 #include "build/build_config.h" |
23 #include "content/browser/plugin_process_host.h" | 20 #include "content/browser/plugin_process_host.h" |
24 #include "content/browser/ppapi_plugin_process_host.h" | 21 #include "content/browser/ppapi_plugin_process_host.h" |
25 #include "content/browser/ppapi_broker_process_host.h" | 22 #include "content/browser/ppapi_broker_process_host.h" |
26 #include "content/common/notification_observer.h" | 23 #include "content/common/notification_observer.h" |
27 #include "content/common/notification_registrar.h" | 24 #include "content/common/notification_registrar.h" |
28 #include "googleurl/src/gurl.h" | 25 #include "googleurl/src/gurl.h" |
29 #include "ipc/ipc_channel_handle.h" | 26 #include "ipc/ipc_channel_handle.h" |
30 #include "webkit/plugins/webplugininfo.h" | 27 #include "webkit/plugins/webplugininfo.h" |
31 | 28 |
32 #if defined(OS_WIN) | 29 #if defined(OS_WIN) |
33 #include "base/memory/scoped_ptr.h" | 30 #include "base/memory/scoped_ptr.h" |
34 #include "base/win/registry.h" | 31 #include "base/win/registry.h" |
35 #endif | 32 #endif |
36 | 33 |
37 #if defined(OS_POSIX) && !defined(OS_MACOSX) | 34 #if defined(OS_POSIX) && !defined(OS_MACOSX) |
38 #include "base/files/file_path_watcher.h" | 35 #include "base/files/file_path_watcher.h" |
39 #endif | 36 #endif |
40 | 37 |
41 struct PepperPluginInfo; | 38 struct PepperPluginInfo; |
42 class PluginDirWatcherDelegate; | 39 class PluginDirWatcherDelegate; |
43 | 40 |
| 41 namespace content { |
| 42 class ResourceContext; |
| 43 class PluginServiceFilter; |
| 44 } |
| 45 |
44 // This must be created on the main thread but it's only called on the IO/file | 46 // This must be created on the main thread but it's only called on the IO/file |
45 // thread. | 47 // thread. |
46 class PluginService | 48 class PluginService |
47 : public base::WaitableEventWatcher::Delegate, | 49 : public base::WaitableEventWatcher::Delegate, |
48 public NotificationObserver { | 50 public NotificationObserver { |
49 public: | 51 public: |
50 struct OverriddenPlugin { | 52 struct OverriddenPlugin { |
51 int render_process_id; | 53 int render_process_id; |
52 int render_view_id; | 54 int render_view_id; |
53 GURL url; // If empty, the override applies to all urls in render_view. | 55 GURL url; // If empty, the override applies to all urls in render_view. |
54 webkit::WebPluginInfo plugin; | 56 webkit::WebPluginInfo plugin; |
55 }; | 57 }; |
56 | 58 |
57 // Returns the PluginService singleton. | 59 // Returns the PluginService singleton. |
58 static PluginService* GetInstance(); | 60 static PluginService* GetInstance(); |
59 | 61 |
| 62 // Starts watching for changes in the list of installed plug-ins. |
| 63 void StartWatchingPlugins(); |
| 64 |
60 // Gets the browser's UI locale. | 65 // Gets the browser's UI locale. |
61 const std::string& GetUILocale(); | 66 const std::string& GetUILocale(); |
62 | 67 |
63 // Returns the plugin process host corresponding to the plugin process that | 68 // Returns the plugin process host corresponding to the plugin process that |
64 // has been started by this service. Returns NULL if no process has been | 69 // has been started by this service. Returns NULL if no process has been |
65 // started. | 70 // started. |
66 PluginProcessHost* FindNpapiPluginProcess(const FilePath& plugin_path); | 71 PluginProcessHost* FindNpapiPluginProcess(const FilePath& plugin_path); |
67 PpapiPluginProcessHost* FindPpapiPluginProcess(const FilePath& plugin_path); | 72 PpapiPluginProcessHost* FindPpapiPluginProcess(const FilePath& plugin_path); |
68 PpapiBrokerProcessHost* FindPpapiBrokerProcess(const FilePath& broker_path); | 73 PpapiBrokerProcessHost* FindPpapiBrokerProcess(const FilePath& broker_path); |
69 | 74 |
70 // Returns the plugin process host corresponding to the plugin process that | 75 // Returns the plugin process host corresponding to the plugin process that |
71 // has been started by this service. This will start a process to host the | 76 // has been started by this service. This will start a process to host the |
72 // 'plugin_path' if needed. If the process fails to start, the return value | 77 // 'plugin_path' if needed. If the process fails to start, the return value |
73 // is NULL. Must be called on the IO thread. | 78 // is NULL. Must be called on the IO thread. |
74 PluginProcessHost* FindOrStartNpapiPluginProcess( | 79 PluginProcessHost* FindOrStartNpapiPluginProcess( |
75 const FilePath& plugin_path); | 80 const FilePath& plugin_path); |
76 PpapiPluginProcessHost* FindOrStartPpapiPluginProcess( | 81 PpapiPluginProcessHost* FindOrStartPpapiPluginProcess( |
77 const FilePath& plugin_path, | 82 const FilePath& plugin_path, |
78 PpapiPluginProcessHost::Client* client); | 83 PpapiPluginProcessHost::Client* client); |
79 PpapiBrokerProcessHost* FindOrStartPpapiBrokerProcess( | 84 PpapiBrokerProcessHost* FindOrStartPpapiBrokerProcess( |
80 const FilePath& plugin_path); | 85 const FilePath& plugin_path); |
81 | 86 |
82 // Opens a channel to a plugin process for the given mime type, starting | 87 // Opens a channel to a plugin process for the given mime type, starting |
83 // a new plugin process if necessary. This must be called on the IO thread | 88 // a new plugin process if necessary. This must be called on the IO thread |
84 // or else a deadlock can occur. | 89 // or else a deadlock can occur. |
85 void OpenChannelToNpapiPlugin(int render_process_id, | 90 void OpenChannelToNpapiPlugin(int render_process_id, |
86 int render_view_id, | 91 int render_view_id, |
87 const GURL& url, | 92 const GURL& url, |
| 93 const GURL& page_url, |
88 const std::string& mime_type, | 94 const std::string& mime_type, |
89 PluginProcessHost::Client* client); | 95 PluginProcessHost::Client* client); |
90 void OpenChannelToPpapiPlugin(const FilePath& path, | 96 void OpenChannelToPpapiPlugin(const FilePath& path, |
91 PpapiPluginProcessHost::Client* client); | 97 PpapiPluginProcessHost::Client* client); |
92 void OpenChannelToPpapiBroker(const FilePath& path, | 98 void OpenChannelToPpapiBroker(const FilePath& path, |
93 PpapiBrokerProcessHost::Client* client); | 99 PpapiBrokerProcessHost::Client* client); |
94 | 100 |
95 // Gets the plugin in the list of plugins that matches the given url and mime | 101 // Gets the plugin in the list of plugins that matches the given url and mime |
96 // type. Must be called on the FILE thread. | 102 // type. Must be called on the FILE thread if |use_stale| is NULL. |
97 bool GetPluginInfo(int render_process_id, | 103 bool GetPluginInfo(int render_process_id, |
98 int render_view_id, | 104 int render_view_id, |
| 105 const content::ResourceContext& context, |
99 const GURL& url, | 106 const GURL& url, |
| 107 const GURL& page_url, |
100 const std::string& mime_type, | 108 const std::string& mime_type, |
| 109 bool allow_wildcard, |
| 110 bool* use_stale, |
101 webkit::WebPluginInfo* info, | 111 webkit::WebPluginInfo* info, |
102 std::string* actual_mime_type); | 112 std::string* actual_mime_type); |
103 | 113 |
104 // Safe to be called from any thread. | 114 // Returns a list of all plug-ins available to the resource context. Must be |
105 void OverridePluginForTab(const OverriddenPlugin& plugin); | 115 // called on the FILE thread. |
106 | 116 void GetPlugins(const content::ResourceContext& context, |
107 // Restricts the given plugin to the the scheme and host of the given url. | 117 std::vector<webkit::WebPluginInfo>* plugins); |
108 // Call with an empty url to reset this. | |
109 // Can be called on any thread. | |
110 void RestrictPluginToUrl(const FilePath& plugin_path, const GURL& url); | |
111 | |
112 // Returns true if the given plugin is allowed to be used by a page with | |
113 // the given URL. | |
114 // Can be called on any thread. | |
115 bool PluginAllowedForURL(const FilePath& plugin_path, const GURL& url); | |
116 | 118 |
117 // Tells all the renderer processes to throw away their cache of the plugin | 119 // Tells all the renderer processes to throw away their cache of the plugin |
118 // list, and optionally also reload all the pages with plugins. | 120 // list, and optionally also reload all the pages with plugins. |
119 // NOTE: can only be called on the UI thread. | 121 // NOTE: can only be called on the UI thread. |
120 static void PurgePluginListCache(bool reload_pages); | 122 static void PurgePluginListCache(bool reload_pages); |
121 | 123 |
| 124 void set_filter(content::PluginServiceFilter* filter) { |
| 125 filter_ = filter; |
| 126 } |
| 127 |
122 private: | 128 private: |
123 friend struct DefaultSingletonTraits<PluginService>; | 129 friend struct DefaultSingletonTraits<PluginService>; |
124 | 130 |
125 // Creates the PluginService object, but doesn't actually build the plugin | 131 // Creates the PluginService object, but doesn't actually build the plugin |
126 // list yet. It's generated lazily. | 132 // list yet. It's generated lazily. |
127 PluginService(); | 133 PluginService(); |
128 virtual ~PluginService(); | 134 virtual ~PluginService(); |
129 | 135 |
130 // base::WaitableEventWatcher::Delegate implementation. | 136 // base::WaitableEventWatcher::Delegate implementation. |
131 virtual void OnWaitableEventSignaled(base::WaitableEvent* waitable_event); | 137 virtual void OnWaitableEventSignaled(base::WaitableEvent* waitable_event); |
132 | 138 |
133 // NotificationObserver implementation | 139 // NotificationObserver implementation |
134 virtual void Observe(int type, const NotificationSource& source, | 140 virtual void Observe(int type, const NotificationSource& source, |
135 const NotificationDetails& details); | 141 const NotificationDetails& details); |
136 | 142 |
137 void RegisterPepperPlugins(); | 143 void RegisterPepperPlugins(); |
138 | 144 |
139 PepperPluginInfo* GetRegisteredPpapiPluginInfo(const FilePath& plugin_path); | 145 PepperPluginInfo* GetRegisteredPpapiPluginInfo(const FilePath& plugin_path); |
140 | 146 |
141 // Helper so we can do the plugin lookup on the FILE thread. | 147 // Helper so we can do the plugin lookup on the FILE thread. |
142 void GetAllowedPluginForOpenChannelToPlugin( | 148 void GetAllowedPluginForOpenChannelToPlugin( |
143 int render_process_id, | 149 int render_process_id, |
144 int render_view_id, | 150 int render_view_id, |
145 const GURL& url, | 151 const GURL& url, |
| 152 const GURL& page_url, |
146 const std::string& mime_type, | 153 const std::string& mime_type, |
147 PluginProcessHost::Client* client); | 154 PluginProcessHost::Client* client); |
148 | 155 |
149 // Helper so we can finish opening the channel after looking up the | 156 // Helper so we can finish opening the channel after looking up the |
150 // plugin. | 157 // plugin. |
151 void FinishOpenChannelToPlugin( | 158 void FinishOpenChannelToPlugin( |
152 const FilePath& plugin_path, | 159 const FilePath& plugin_path, |
153 PluginProcessHost::Client* client); | 160 PluginProcessHost::Client* client); |
154 | 161 |
155 #if defined(OS_POSIX) && !defined(OS_MACOSX) | 162 #if defined(OS_POSIX) && !defined(OS_MACOSX) |
156 // Registers a new FilePathWatcher for a given path. | 163 // Registers a new FilePathWatcher for a given path. |
157 static void RegisterFilePathWatcher( | 164 static void RegisterFilePathWatcher( |
158 base::files::FilePathWatcher* watcher, | 165 base::files::FilePathWatcher* watcher, |
159 const FilePath& path, | 166 const FilePath& path, |
160 base::files::FilePathWatcher::Delegate* delegate); | 167 base::files::FilePathWatcher::Delegate* delegate); |
161 #endif | 168 #endif |
162 | 169 |
163 // The browser's UI locale. | 170 // The browser's UI locale. |
164 const std::string ui_locale_; | 171 const std::string ui_locale_; |
165 | 172 |
166 // Map of plugin paths to the origin they are restricted to. | |
167 base::Lock restricted_plugin_lock_; // Guards access to restricted_plugin_. | |
168 typedef base::hash_map<FilePath, GURL> RestrictedPluginMap; | |
169 RestrictedPluginMap restricted_plugin_; | |
170 | |
171 NotificationRegistrar registrar_; | 173 NotificationRegistrar registrar_; |
172 | 174 |
173 #if defined(OS_WIN) | 175 #if defined(OS_WIN) |
174 // Registry keys for getting notifications when new plugins are installed. | 176 // Registry keys for getting notifications when new plugins are installed. |
175 base::win::RegKey hkcu_key_; | 177 base::win::RegKey hkcu_key_; |
176 base::win::RegKey hklm_key_; | 178 base::win::RegKey hklm_key_; |
177 scoped_ptr<base::WaitableEvent> hkcu_event_; | 179 scoped_ptr<base::WaitableEvent> hkcu_event_; |
178 scoped_ptr<base::WaitableEvent> hklm_event_; | 180 scoped_ptr<base::WaitableEvent> hklm_event_; |
179 base::WaitableEventWatcher hkcu_watcher_; | 181 base::WaitableEventWatcher hkcu_watcher_; |
180 base::WaitableEventWatcher hklm_watcher_; | 182 base::WaitableEventWatcher hklm_watcher_; |
181 #endif | 183 #endif |
182 | 184 |
183 #if defined(OS_POSIX) && !defined(OS_MACOSX) | 185 #if defined(OS_POSIX) && !defined(OS_MACOSX) |
184 ScopedVector<base::files::FilePathWatcher> file_watchers_; | 186 ScopedVector<base::files::FilePathWatcher> file_watchers_; |
185 scoped_refptr<PluginDirWatcherDelegate> file_watcher_delegate_; | 187 scoped_refptr<PluginDirWatcherDelegate> file_watcher_delegate_; |
186 #endif | 188 #endif |
187 | 189 |
188 std::vector<PepperPluginInfo> ppapi_plugins_; | 190 std::vector<PepperPluginInfo> ppapi_plugins_; |
189 | 191 |
190 std::vector<OverriddenPlugin> overridden_plugins_; | 192 // Weak pointer; outlives us. |
191 base::Lock overridden_plugins_lock_; | 193 content::PluginServiceFilter* filter_; |
192 | 194 |
193 DISALLOW_COPY_AND_ASSIGN(PluginService); | 195 DISALLOW_COPY_AND_ASSIGN(PluginService); |
194 }; | 196 }; |
195 | 197 |
196 DISABLE_RUNNABLE_METHOD_REFCOUNT(PluginService); | 198 DISABLE_RUNNABLE_METHOD_REFCOUNT(PluginService); |
197 | 199 |
198 #endif // CONTENT_BROWSER_PLUGIN_SERVICE_H_ | 200 #endif // CONTENT_BROWSER_PLUGIN_SERVICE_H_ |
OLD | NEW |