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 #include "chrome/browser/plugin_prefs.h" | 5 #include "chrome/browser/plugin_prefs.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" |
(...skipping 13 matching lines...) Expand all Loading... |
24 #include "chrome/browser/profiles/profile_dependency_manager.h" | 24 #include "chrome/browser/profiles/profile_dependency_manager.h" |
25 #include "chrome/browser/profiles/profile_keyed_service.h" | 25 #include "chrome/browser/profiles/profile_keyed_service.h" |
26 #include "chrome/browser/profiles/profile_keyed_service_factory.h" | 26 #include "chrome/browser/profiles/profile_keyed_service_factory.h" |
27 #include "chrome/browser/profiles/profile_manager.h" | 27 #include "chrome/browser/profiles/profile_manager.h" |
28 #include "chrome/common/chrome_content_client.h" | 28 #include "chrome/common/chrome_content_client.h" |
29 #include "chrome/common/chrome_notification_types.h" | 29 #include "chrome/common/chrome_notification_types.h" |
30 #include "chrome/common/chrome_paths.h" | 30 #include "chrome/common/chrome_paths.h" |
31 #include "chrome/common/chrome_switches.h" | 31 #include "chrome/common/chrome_switches.h" |
32 #include "chrome/common/pref_names.h" | 32 #include "chrome/common/pref_names.h" |
33 #include "content/browser/browser_thread.h" | 33 #include "content/browser/browser_thread.h" |
| 34 #include "content/browser/plugin_service.h" |
34 #include "content/common/notification_service.h" | 35 #include "content/common/notification_service.h" |
35 #include "webkit/plugins/npapi/plugin_group.h" | 36 #include "webkit/plugins/npapi/plugin_group.h" |
36 #include "webkit/plugins/npapi/plugin_list.h" | 37 #include "webkit/plugins/npapi/plugin_list.h" |
37 #include "webkit/plugins/webplugininfo.h" | 38 #include "webkit/plugins/webplugininfo.h" |
38 | 39 |
39 namespace { | 40 namespace { |
40 | 41 |
41 class PluginPrefsWrapper : public ProfileKeyedService { | 42 class PluginPrefsWrapper : public ProfileKeyedService { |
42 public: | 43 public: |
43 explicit PluginPrefsWrapper(scoped_refptr<PluginPrefs> plugin_prefs) | 44 explicit PluginPrefsWrapper(scoped_refptr<PluginPrefs> plugin_prefs) |
(...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
148 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, | 149 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, |
149 base::Bind(&PluginPrefs::OnUpdatePreferences, this, groups)); | 150 base::Bind(&PluginPrefs::OnUpdatePreferences, this, groups)); |
150 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, | 151 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, |
151 base::Bind(&PluginPrefs::NotifyPluginStatusChanged, this)); | 152 base::Bind(&PluginPrefs::NotifyPluginStatusChanged, this)); |
152 } | 153 } |
153 | 154 |
154 bool PluginPrefs::EnablePlugin(bool enabled, const FilePath& path) { | 155 bool PluginPrefs::EnablePlugin(bool enabled, const FilePath& path) { |
155 // Do policy checks first. These don't need to run on the FILE thread. | 156 // Do policy checks first. These don't need to run on the FILE thread. |
156 webkit::npapi::PluginList* plugin_list = GetPluginList(); | 157 webkit::npapi::PluginList* plugin_list = GetPluginList(); |
157 webkit::WebPluginInfo plugin; | 158 webkit::WebPluginInfo plugin; |
158 if (plugin_list->GetPluginInfoByPath(path, &plugin)) { | 159 if (PluginService::GetInstance()->GetPluginInfoByPath(path, &plugin)) { |
159 scoped_ptr<webkit::npapi::PluginGroup> group( | 160 scoped_ptr<webkit::npapi::PluginGroup> group( |
160 plugin_list->GetPluginGroup(plugin)); | 161 plugin_list->GetPluginGroup(plugin)); |
161 PolicyStatus plugin_status = PolicyStatusForPlugin(plugin.name); | 162 PolicyStatus plugin_status = PolicyStatusForPlugin(plugin.name); |
162 PolicyStatus group_status = PolicyStatusForPlugin(group->GetGroupName()); | 163 PolicyStatus group_status = PolicyStatusForPlugin(group->GetGroupName()); |
163 if (enabled) { | 164 if (enabled) { |
164 if (plugin_status == POLICY_DISABLED || group_status == POLICY_DISABLED) | 165 if (plugin_status == POLICY_DISABLED || group_status == POLICY_DISABLED) |
165 return false; | 166 return false; |
166 } else { | 167 } else { |
167 if (plugin_status == POLICY_ENABLED || group_status == POLICY_ENABLED) | 168 if (plugin_status == POLICY_ENABLED || group_status == POLICY_ENABLED) |
168 return false; | 169 return false; |
(...skipping 465 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
634 PrefService::UNSYNCABLE_PREF); | 635 PrefService::UNSYNCABLE_PREF); |
635 prefs->RegisterListPref(prefs::kPluginsPluginsList, | 636 prefs->RegisterListPref(prefs::kPluginsPluginsList, |
636 PrefService::UNSYNCABLE_PREF); | 637 PrefService::UNSYNCABLE_PREF); |
637 prefs->RegisterListPref(prefs::kPluginsDisabledPlugins, | 638 prefs->RegisterListPref(prefs::kPluginsDisabledPlugins, |
638 PrefService::UNSYNCABLE_PREF); | 639 PrefService::UNSYNCABLE_PREF); |
639 prefs->RegisterListPref(prefs::kPluginsDisabledPluginsExceptions, | 640 prefs->RegisterListPref(prefs::kPluginsDisabledPluginsExceptions, |
640 PrefService::UNSYNCABLE_PREF); | 641 PrefService::UNSYNCABLE_PREF); |
641 prefs->RegisterListPref(prefs::kPluginsEnabledPlugins, | 642 prefs->RegisterListPref(prefs::kPluginsEnabledPlugins, |
642 PrefService::UNSYNCABLE_PREF); | 643 PrefService::UNSYNCABLE_PREF); |
643 } | 644 } |
OLD | NEW |