| 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 <set> | 12 #include <set> |
| 13 #include <string> | |
| 14 #include <vector> | |
| 15 | 13 |
| 16 #include "base/basictypes.h" | 14 #include "base/basictypes.h" |
| 17 #include "base/callback.h" | |
| 18 #include "base/memory/scoped_vector.h" | 15 #include "base/memory/scoped_vector.h" |
| 19 #include "base/memory/singleton.h" | 16 #include "base/memory/singleton.h" |
| 20 #include "base/synchronization/waitable_event_watcher.h" | 17 #include "base/synchronization/waitable_event_watcher.h" |
| 21 #include "build/build_config.h" | 18 #include "build/build_config.h" |
| 22 #include "content/browser/plugin_process_host.h" | 19 #include "content/browser/plugin_process_host.h" |
| 23 #include "content/browser/ppapi_plugin_process_host.h" | 20 #include "content/browser/ppapi_plugin_process_host.h" |
| 24 #include "content/common/content_export.h" | 21 #include "content/common/content_export.h" |
| 25 #include "content/public/browser/notification_observer.h" | 22 #include "content/public/browser/notification_observer.h" |
| 26 #include "content/public/browser/notification_registrar.h" | 23 #include "content/public/browser/notification_registrar.h" |
| 24 #include "content/public/browser/plugin_service.h" |
| 27 #include "googleurl/src/gurl.h" | 25 #include "googleurl/src/gurl.h" |
| 28 #include "ipc/ipc_channel_handle.h" | 26 #include "ipc/ipc_channel_handle.h" |
| 29 | 27 |
| 30 #if defined(OS_WIN) | 28 #if defined(OS_WIN) |
| 31 #include "base/memory/scoped_ptr.h" | 29 #include "base/memory/scoped_ptr.h" |
| 32 #include "base/win/registry.h" | 30 #include "base/win/registry.h" |
| 33 #endif | 31 #endif |
| 34 | 32 |
| 35 #if defined(OS_POSIX) && !defined(OS_MACOSX) && !defined(OS_OPENBSD) | 33 #if defined(OS_POSIX) && !defined(OS_MACOSX) && !defined(OS_OPENBSD) |
| 36 #include "base/files/file_path_watcher.h" | 34 #include "base/files/file_path_watcher.h" |
| (...skipping 14 matching lines...) Expand all Loading... |
| 51 struct PluginServiceFilterParams; | 49 struct PluginServiceFilterParams; |
| 52 } | 50 } |
| 53 | 51 |
| 54 namespace webkit { | 52 namespace webkit { |
| 55 namespace npapi { | 53 namespace npapi { |
| 56 class PluginGroup; | 54 class PluginGroup; |
| 57 class PluginList; | 55 class PluginList; |
| 58 } | 56 } |
| 59 } | 57 } |
| 60 | 58 |
| 61 // This must be created on the main thread but it's only called on the IO/file | |
| 62 // thread. This is an asynchronous wrapper around the PluginList interface for | |
| 63 // querying plugin information. This must be used instead of that to avoid | |
| 64 // doing expensive disk operations on the IO/UI threads. | |
| 65 class CONTENT_EXPORT PluginService | 59 class CONTENT_EXPORT PluginService |
| 66 : public base::WaitableEventWatcher::Delegate, | 60 : public content::PluginService, |
| 61 public base::WaitableEventWatcher::Delegate, |
| 67 public content::NotificationObserver { | 62 public content::NotificationObserver { |
| 68 public: | 63 public: |
| 69 struct OverriddenPlugin { | |
| 70 int render_process_id; | |
| 71 int render_view_id; | |
| 72 GURL url; // If empty, the override applies to all urls in render_view. | |
| 73 webkit::WebPluginInfo plugin; | |
| 74 }; | |
| 75 | |
| 76 typedef base::Callback<void(const std::vector<webkit::WebPluginInfo>&)> | |
| 77 GetPluginsCallback; | |
| 78 typedef base::Callback<void(const std::vector<webkit::npapi::PluginGroup>&)> | |
| 79 GetPluginGroupsCallback; | |
| 80 | |
| 81 // Returns the PluginService singleton. | 64 // Returns the PluginService singleton. |
| 82 static PluginService* GetInstance(); | 65 static PluginService* GetInstance(); |
| 83 | 66 |
| 84 // Must be called on the instance to finish initialization. | 67 // content::PluginService implementation: |
| 85 void Init(); | 68 virtual void Init() OVERRIDE; |
| 86 | 69 virtual void StartWatchingPlugins() OVERRIDE; |
| 87 // Starts watching for changes in the list of installed plug-ins. | 70 virtual PluginProcessHost* FindNpapiPluginProcess( |
| 88 void StartWatchingPlugins(); | 71 const FilePath& plugin_path) OVERRIDE; |
| 72 virtual bool GetPluginInfoArray( |
| 73 const GURL& url, |
| 74 const std::string& mime_type, |
| 75 bool allow_wildcard, |
| 76 std::vector<webkit::WebPluginInfo>* info, |
| 77 std::vector<std::string>* actual_mime_types) OVERRIDE; |
| 78 virtual bool GetPluginInfo(int render_process_id, |
| 79 int render_view_id, |
| 80 const content::ResourceContext& context, |
| 81 const GURL& url, |
| 82 const GURL& page_url, |
| 83 const std::string& mime_type, |
| 84 bool allow_wildcard, |
| 85 bool* is_stale, |
| 86 webkit::WebPluginInfo* info, |
| 87 std::string* actual_mime_type) OVERRIDE; |
| 88 virtual bool GetPluginInfoByPath(const FilePath& plugin_path, |
| 89 webkit::WebPluginInfo* info) OVERRIDE; |
| 90 virtual void GetPlugins(const GetPluginsCallback& callback) OVERRIDE; |
| 91 virtual void GetPluginGroups( |
| 92 const GetPluginGroupsCallback& callback) OVERRIDE; |
| 93 virtual content::PepperPluginInfo* GetRegisteredPpapiPluginInfo( |
| 94 const FilePath& plugin_path) OVERRIDE; |
| 95 virtual void SetFilter(content::PluginServiceFilter* filter) OVERRIDE; |
| 96 virtual content::PluginServiceFilter* GetFilter() OVERRIDE; |
| 97 virtual void RefreshPlugins() OVERRIDE; |
| 98 virtual void AddExtraPluginPath(const FilePath& path) OVERRIDE; |
| 99 virtual void RemoveExtraPluginPath(const FilePath& path) OVERRIDE; |
| 100 virtual void UnregisterInternalPlugin(const FilePath& path) OVERRIDE; |
| 101 virtual void RegisterInternalPlugin( |
| 102 const webkit::WebPluginInfo& info) OVERRIDE; |
| 103 virtual string16 GetPluginGroupName(const std::string& plugin_name) OVERRIDE; |
| 104 virtual webkit::npapi::PluginList* GetPluginList() OVERRIDE; |
| 89 | 105 |
| 90 // Gets the browser's UI locale. | 106 // Gets the browser's UI locale. |
| 91 const std::string& GetUILocale(); | 107 const std::string& GetUILocale(); |
| 92 | 108 |
| 93 // Returns the plugin process host corresponding to the plugin process that | 109 // Like FindNpapiPluginProcess but for Pepper. |
| 94 // has been started by this service. Returns NULL if no process has been | |
| 95 // started. | |
| 96 PluginProcessHost* FindNpapiPluginProcess(const FilePath& plugin_path); | |
| 97 PpapiPluginProcessHost* FindPpapiPluginProcess(const FilePath& plugin_path); | 110 PpapiPluginProcessHost* FindPpapiPluginProcess(const FilePath& plugin_path); |
| 98 PpapiPluginProcessHost* FindPpapiBrokerProcess(const FilePath& broker_path); | 111 PpapiPluginProcessHost* FindPpapiBrokerProcess(const FilePath& broker_path); |
| 99 | 112 |
| 100 // Returns the plugin process host corresponding to the plugin process that | 113 // Returns the plugin process host corresponding to the plugin process that |
| 101 // has been started by this service. This will start a process to host the | 114 // has been started by this service. This will start a process to host the |
| 102 // 'plugin_path' if needed. If the process fails to start, the return value | 115 // 'plugin_path' if needed. If the process fails to start, the return value |
| 103 // is NULL. Must be called on the IO thread. | 116 // is NULL. Must be called on the IO thread. |
| 104 PluginProcessHost* FindOrStartNpapiPluginProcess( | 117 PluginProcessHost* FindOrStartNpapiPluginProcess( |
| 105 const FilePath& plugin_path); | 118 const FilePath& plugin_path); |
| 106 PpapiPluginProcessHost* FindOrStartPpapiPluginProcess( | 119 PpapiPluginProcessHost* FindOrStartPpapiPluginProcess( |
| (...skipping 12 matching lines...) Expand all Loading... |
| 119 const std::string& mime_type, | 132 const std::string& mime_type, |
| 120 PluginProcessHost::Client* client); | 133 PluginProcessHost::Client* client); |
| 121 void OpenChannelToPpapiPlugin(const FilePath& path, | 134 void OpenChannelToPpapiPlugin(const FilePath& path, |
| 122 PpapiPluginProcessHost::PluginClient* client); | 135 PpapiPluginProcessHost::PluginClient* client); |
| 123 void OpenChannelToPpapiBroker(const FilePath& path, | 136 void OpenChannelToPpapiBroker(const FilePath& path, |
| 124 PpapiPluginProcessHost::BrokerClient* client); | 137 PpapiPluginProcessHost::BrokerClient* client); |
| 125 | 138 |
| 126 // Cancels opening a channel to a NPAPI plugin. | 139 // Cancels opening a channel to a NPAPI plugin. |
| 127 void CancelOpenChannelToNpapiPlugin(PluginProcessHost::Client* client); | 140 void CancelOpenChannelToNpapiPlugin(PluginProcessHost::Client* client); |
| 128 | 141 |
| 129 // Gets the plugin in the list of plugins that matches the given url and mime | |
| 130 // type. Returns true if the data is frome a stale plugin list, false if it | |
| 131 // is up to date. This can be called from any thread. | |
| 132 bool GetPluginInfoArray(const GURL& url, | |
| 133 const std::string& mime_type, | |
| 134 bool allow_wildcard, | |
| 135 std::vector<webkit::WebPluginInfo>* info, | |
| 136 std::vector<std::string>* actual_mime_types); | |
| 137 | |
| 138 // Gets plugin info for an individual plugin and filters the plugins using | |
| 139 // the |context| and renderer IDs. This will report whether the data is stale | |
| 140 // via |is_stale| and returns whether or not the plugin can be found. | |
| 141 bool GetPluginInfo(int render_process_id, | |
| 142 int render_view_id, | |
| 143 const content::ResourceContext& context, | |
| 144 const GURL& url, | |
| 145 const GURL& page_url, | |
| 146 const std::string& mime_type, | |
| 147 bool allow_wildcard, | |
| 148 bool* is_stale, | |
| 149 webkit::WebPluginInfo* info, | |
| 150 std::string* actual_mime_type); | |
| 151 | |
| 152 // Get plugin info by plugin path (including disabled plugins). Returns true | |
| 153 // if the plugin is found and WebPluginInfo has been filled in |info|. This | |
| 154 // will use cached data in the plugin list. | |
| 155 bool GetPluginInfoByPath(const FilePath& plugin_path, | |
| 156 webkit::WebPluginInfo* info); | |
| 157 | |
| 158 // Asynchronously loads plugins if necessary and then calls back to the | |
| 159 // provided function on the calling MessageLoop on completion. | |
| 160 void GetPlugins(const GetPluginsCallback& callback); | |
| 161 | |
| 162 // Asynchronously loads the list of plugin groups if necessary and then calls | |
| 163 // back to the provided function on the calling MessageLoop on completion. | |
| 164 void GetPluginGroups(const GetPluginGroupsCallback& callback); | |
| 165 | |
| 166 // Returns information about a pepper plugin if it exists, otherwise NULL. | |
| 167 // The caller does not own the pointer, and it's not guaranteed to live past | |
| 168 // the call stack. | |
| 169 content::PepperPluginInfo* GetRegisteredPpapiPluginInfo( | |
| 170 const FilePath& plugin_path); | |
| 171 | |
| 172 // Tells all the renderer processes associated with the given browser context | |
| 173 // to throw away their cache of the plugin list, and optionally also reload | |
| 174 // all the pages with plugins. If |browser_context| is NULL, purges the cache | |
| 175 // in all renderers. | |
| 176 // NOTE: can only be called on the UI thread. | |
| 177 static void PurgePluginListCache(content::BrowserContext* browser_context, | |
| 178 bool reload_pages); | |
| 179 | |
| 180 void set_filter(content::PluginServiceFilter* filter) { | |
| 181 filter_ = filter; | |
| 182 } | |
| 183 content::PluginServiceFilter* filter() { return filter_; } | |
| 184 | |
| 185 // The following functions are wrappers around webkit::npapi::PluginList. | |
| 186 // These must be used instead of those in order to ensure that we have a | |
| 187 // single global list in the component build and so that we don't | |
| 188 // accidentally load plugins in the wrong process or thread. Refer to | |
| 189 // PluginList for further documentation of these functions. | |
| 190 void RefreshPlugins(); | |
| 191 void AddExtraPluginPath(const FilePath& path); | |
| 192 void RemoveExtraPluginPath(const FilePath& path); | |
| 193 void UnregisterInternalPlugin(const FilePath& path); | |
| 194 void RegisterInternalPlugin(const webkit::WebPluginInfo& info); | |
| 195 string16 GetPluginGroupName(const std::string& plugin_name); | |
| 196 | |
| 197 // TODO(dpranke): This should be private. | |
| 198 webkit::npapi::PluginList* plugin_list() { return plugin_list_; } | |
| 199 | |
| 200 void SetPluginListForTesting(webkit::npapi::PluginList* plugin_list); | 142 void SetPluginListForTesting(webkit::npapi::PluginList* plugin_list); |
| 201 | 143 |
| 202 private: | 144 private: |
| 203 friend struct DefaultSingletonTraits<PluginService>; | 145 friend struct DefaultSingletonTraits<PluginService>; |
| 204 | 146 |
| 205 // Creates the PluginService object, but doesn't actually build the plugin | 147 // Creates the PluginService object, but doesn't actually build the plugin |
| 206 // list yet. It's generated lazily. | 148 // list yet. It's generated lazily. |
| 207 PluginService(); | 149 PluginService(); |
| 208 virtual ~PluginService(); | 150 virtual ~PluginService(); |
| 209 | 151 |
| (...skipping 77 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 287 #if defined(OS_POSIX) | 229 #if defined(OS_POSIX) |
| 288 scoped_refptr<PluginLoaderPosix> plugin_loader_; | 230 scoped_refptr<PluginLoaderPosix> plugin_loader_; |
| 289 #endif | 231 #endif |
| 290 | 232 |
| 291 DISALLOW_COPY_AND_ASSIGN(PluginService); | 233 DISALLOW_COPY_AND_ASSIGN(PluginService); |
| 292 }; | 234 }; |
| 293 | 235 |
| 294 DISABLE_RUNNABLE_METHOD_REFCOUNT(PluginService); | 236 DISABLE_RUNNABLE_METHOD_REFCOUNT(PluginService); |
| 295 | 237 |
| 296 #endif // CONTENT_BROWSER_PLUGIN_SERVICE_H_ | 238 #endif // CONTENT_BROWSER_PLUGIN_SERVICE_H_ |
| OLD | NEW |