| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/plugins/plugin_prefs.h" | 5 #include "chrome/browser/plugins/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" |
| 11 #include "base/memory/scoped_ptr.h" | 11 #include "base/memory/scoped_ptr.h" |
| 12 #include "base/message_loop.h" |
| 12 #include "base/path_service.h" | 13 #include "base/path_service.h" |
| 13 #include "base/string_util.h" | 14 #include "base/string_util.h" |
| 14 #include "base/utf_string_conversions.h" | 15 #include "base/utf_string_conversions.h" |
| 15 #include "base/values.h" | 16 #include "base/values.h" |
| 16 #include "build/build_config.h" | 17 #include "build/build_config.h" |
| 17 #include "chrome/browser/plugins/plugin_installer.h" | 18 #include "chrome/browser/plugins/plugin_installer.h" |
| 19 #include "chrome/browser/plugins/plugin_metadata.h" |
| 18 #include "chrome/browser/plugins/plugin_prefs_factory.h" | 20 #include "chrome/browser/plugins/plugin_prefs_factory.h" |
| 21 #include "chrome/browser/browser_process.h" |
| 19 #include "chrome/browser/prefs/scoped_user_pref_update.h" | 22 #include "chrome/browser/prefs/scoped_user_pref_update.h" |
| 20 #include "chrome/browser/profiles/profile.h" | 23 #include "chrome/browser/profiles/profile.h" |
| 21 #include "chrome/browser/profiles/profile_keyed_service.h" | 24 #include "chrome/browser/profiles/profile_keyed_service.h" |
| 22 #include "chrome/common/chrome_constants.h" | 25 #include "chrome/common/chrome_constants.h" |
| 23 #include "chrome/common/chrome_content_client.h" | 26 #include "chrome/common/chrome_content_client.h" |
| 24 #include "chrome/common/chrome_notification_types.h" | 27 #include "chrome/common/chrome_notification_types.h" |
| 25 #include "chrome/common/chrome_paths.h" | 28 #include "chrome/common/chrome_paths.h" |
| 26 #include "chrome/common/chrome_switches.h" | 29 #include "chrome/common/chrome_switches.h" |
| 27 #include "chrome/common/pref_names.h" | 30 #include "chrome/common/pref_names.h" |
| 28 #include "content/public/browser/browser_thread.h" | 31 #include "content/public/browser/browser_thread.h" |
| (...skipping 72 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 101 PluginPrefsFactory::GetInstance()->SetTestingFactoryAndUse( | 104 PluginPrefsFactory::GetInstance()->SetTestingFactoryAndUse( |
| 102 profile, &PluginPrefsFactory::CreateForTestingProfile).get()); | 105 profile, &PluginPrefsFactory::CreateForTestingProfile).get()); |
| 103 } | 106 } |
| 104 | 107 |
| 105 void PluginPrefs::SetPluginListForTesting( | 108 void PluginPrefs::SetPluginListForTesting( |
| 106 webkit::npapi::PluginList* plugin_list) { | 109 webkit::npapi::PluginList* plugin_list) { |
| 107 plugin_list_ = plugin_list; | 110 plugin_list_ = plugin_list; |
| 108 } | 111 } |
| 109 | 112 |
| 110 void PluginPrefs::EnablePluginGroup(bool enabled, const string16& group_name) { | 113 void PluginPrefs::EnablePluginGroup(bool enabled, const string16& group_name) { |
| 111 PluginFinder::Get( | |
| 112 base::Bind(&PluginPrefs::GetPluginFinderForEnablePluginGroup, | |
| 113 this, enabled, group_name)); | |
| 114 } | |
| 115 | |
| 116 void PluginPrefs::GetPluginFinderForEnablePluginGroup( | |
| 117 bool enabled, | |
| 118 const string16& group_name, | |
| 119 PluginFinder* finder) { | |
| 120 PluginService::GetInstance()->GetPlugins( | 114 PluginService::GetInstance()->GetPlugins( |
| 121 base::Bind(&PluginPrefs::EnablePluginGroupInternal, | 115 base::Bind(&PluginPrefs::EnablePluginGroupInternal, |
| 122 this, enabled, group_name, finder)); | 116 this, enabled, group_name)); |
| 123 } | 117 } |
| 124 | 118 |
| 125 void PluginPrefs::EnablePluginGroupInternal( | 119 void PluginPrefs::EnablePluginGroupInternal( |
| 126 bool enabled, | 120 bool enabled, |
| 127 const string16& group_name, | 121 const string16& group_name, |
| 128 PluginFinder* finder, | |
| 129 const std::vector<webkit::WebPluginInfo>& plugins) { | 122 const std::vector<webkit::WebPluginInfo>& plugins) { |
| 130 base::AutoLock auto_lock(lock_); | 123 base::AutoLock auto_lock(lock_); |
| 124 PluginFinder* finder = PluginFinder::GetInstance(); |
| 131 | 125 |
| 132 // Set the desired state for the group. | 126 // Set the desired state for the group. |
| 133 plugin_group_state_[group_name] = enabled; | 127 plugin_group_state_[group_name] = enabled; |
| 134 | 128 |
| 135 // Update the state for all plug-ins in the group. | 129 // Update the state for all plug-ins in the group. |
| 136 for (size_t i = 0; i < plugins.size(); ++i) { | 130 for (size_t i = 0; i < plugins.size(); ++i) { |
| 137 PluginInstaller* installer = finder->GetPluginInstaller(plugins[i]); | 131 PluginMetadata* plugin = finder->GetPluginMetadata(plugins[i]); |
| 138 if (group_name != installer->name()) | 132 if (group_name != plugin->name()) |
| 139 continue; | 133 continue; |
| 140 plugin_state_.Set(plugins[i].path, enabled); | 134 plugin_state_.Set(plugins[i].path, enabled); |
| 141 } | 135 } |
| 142 | 136 |
| 143 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, | 137 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, |
| 144 base::Bind(&PluginPrefs::OnUpdatePreferences, this, plugins, finder)); | 138 base::Bind(&PluginPrefs::OnUpdatePreferences, this, plugins)); |
| 145 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, | 139 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, |
| 146 base::Bind(&PluginPrefs::NotifyPluginStatusChanged, this)); | 140 base::Bind(&PluginPrefs::NotifyPluginStatusChanged, this)); |
| 147 } | 141 } |
| 148 | 142 |
| 149 void PluginPrefs::EnablePluginIfPossibleCallback( | 143 void PluginPrefs::EnablePlugin( |
| 150 bool enabled, const FilePath& path, | 144 bool enabled, const FilePath& path, |
| 151 const base::Callback<void(bool)>& callback, | 145 const base::Callback<void(bool)>& callback) { |
| 152 PluginFinder* finder) { | 146 PluginFinder* finder = PluginFinder::GetInstance(); |
| 153 webkit::WebPluginInfo plugin; | 147 webkit::WebPluginInfo plugin; |
| 154 bool can_enable = true; | 148 bool can_enable = true; |
| 155 if (PluginService::GetInstance()->GetPluginInfoByPath(path, &plugin)) { | 149 if (PluginService::GetInstance()->GetPluginInfoByPath(path, &plugin)) { |
| 156 PluginInstaller* installer = finder->GetPluginInstaller(plugin); | 150 PluginMetadata* plugin_metadata = finder->GetPluginMetadata(plugin); |
| 157 PolicyStatus plugin_status = PolicyStatusForPlugin(plugin.name); | 151 PolicyStatus plugin_status = PolicyStatusForPlugin(plugin.name); |
| 158 PolicyStatus group_status = PolicyStatusForPlugin(installer->name()); | 152 PolicyStatus group_status = PolicyStatusForPlugin(plugin_metadata->name()); |
| 159 if (enabled) { | 153 if (enabled) { |
| 160 if (plugin_status == POLICY_DISABLED || group_status == POLICY_DISABLED) | 154 if (plugin_status == POLICY_DISABLED || group_status == POLICY_DISABLED) |
| 161 can_enable = false; | 155 can_enable = false; |
| 162 } else { | 156 } else { |
| 163 if (plugin_status == POLICY_ENABLED || group_status == POLICY_ENABLED) | 157 if (plugin_status == POLICY_ENABLED || group_status == POLICY_ENABLED) |
| 164 can_enable = false; | 158 can_enable = false; |
| 165 } | 159 } |
| 166 } else { | 160 } else { |
| 167 NOTREACHED(); | 161 NOTREACHED(); |
| 168 } | 162 } |
| 169 | 163 |
| 170 if (!can_enable) { | 164 if (!can_enable) { |
| 171 callback.Run(false); | 165 MessageLoop::current()->PostTask(FROM_HERE, |
| 166 base::Bind(callback, false)); |
| 172 return; | 167 return; |
| 173 } | 168 } |
| 174 | 169 |
| 175 PluginService::GetInstance()->GetPlugins( | 170 PluginService::GetInstance()->GetPlugins( |
| 176 base::Bind(&PluginPrefs::EnablePluginInternal, this, | 171 base::Bind(&PluginPrefs::EnablePluginInternal, this, |
| 177 enabled, path, finder, callback)); | 172 enabled, path, finder, callback)); |
| 178 } | 173 } |
| 179 | 174 |
| 180 void PluginPrefs::EnablePlugin( | |
| 181 bool enabled, const FilePath& path, | |
| 182 const base::Callback<void(bool)>& callback) { | |
| 183 PluginFinder::Get(base::Bind(&PluginPrefs::EnablePluginIfPossibleCallback, | |
| 184 this, enabled, path, callback)); | |
| 185 } | |
| 186 | |
| 187 void PluginPrefs::EnablePluginInternal( | 175 void PluginPrefs::EnablePluginInternal( |
| 188 bool enabled, | 176 bool enabled, |
| 189 const FilePath& path, | 177 const FilePath& path, |
| 190 PluginFinder* plugin_finder, | 178 PluginFinder* plugin_finder, |
| 191 const base::Callback<void(bool)>& callback, | 179 const base::Callback<void(bool)>& callback, |
| 192 const std::vector<webkit::WebPluginInfo>& plugins) { | 180 const std::vector<webkit::WebPluginInfo>& plugins) { |
| 193 { | 181 { |
| 194 // Set the desired state for the plug-in. | 182 // Set the desired state for the plug-in. |
| 195 base::AutoLock auto_lock(lock_); | 183 base::AutoLock auto_lock(lock_); |
| 196 plugin_state_.Set(path, enabled); | 184 plugin_state_.Set(path, enabled); |
| 197 } | 185 } |
| 198 | 186 |
| 199 string16 group_name; | 187 string16 group_name; |
| 200 for (size_t i = 0; i < plugins.size(); ++i) { | 188 for (size_t i = 0; i < plugins.size(); ++i) { |
| 201 if (plugins[i].path == path) { | 189 if (plugins[i].path == path) { |
| 202 PluginInstaller* installer = | 190 PluginMetadata* plugin_metadata = |
| 203 plugin_finder->GetPluginInstaller(plugins[i]); | 191 plugin_finder->GetPluginMetadata(plugins[i]); |
| 204 // set the group name for this plug-in. | 192 // set the group name for this plug-in. |
| 205 group_name = installer->name(); | 193 group_name = plugin_metadata->name(); |
| 206 DCHECK_EQ(enabled, IsPluginEnabled(plugins[i])); | 194 DCHECK_EQ(enabled, IsPluginEnabled(plugins[i])); |
| 207 break; | 195 break; |
| 208 } | 196 } |
| 209 } | 197 } |
| 210 | 198 |
| 211 bool all_disabled = true; | 199 bool all_disabled = true; |
| 212 for (size_t i = 0; i < plugins.size(); ++i) { | 200 for (size_t i = 0; i < plugins.size(); ++i) { |
| 213 PluginInstaller* installer = plugin_finder->GetPluginInstaller(plugins[i]); | 201 PluginMetadata* plugin_metadata = |
| 214 DCHECK(!installer->name().empty()); | 202 plugin_finder->GetPluginMetadata(plugins[i]); |
| 215 if (group_name == installer->name()) { | 203 DCHECK(!plugin_metadata->name().empty()); |
| 204 if (group_name == plugin_metadata->name()) { |
| 216 all_disabled = all_disabled && !IsPluginEnabled(plugins[i]); | 205 all_disabled = all_disabled && !IsPluginEnabled(plugins[i]); |
| 217 } | 206 } |
| 218 } | 207 } |
| 219 | 208 |
| 220 if (!group_name.empty()) { | 209 if (!group_name.empty()) { |
| 221 // Update the state for the corresponding plug-in group. | 210 // Update the state for the corresponding plug-in group. |
| 222 base::AutoLock auto_lock(lock_); | 211 base::AutoLock auto_lock(lock_); |
| 223 plugin_group_state_[group_name] = !all_disabled; | 212 plugin_group_state_[group_name] = !all_disabled; |
| 224 } | 213 } |
| 225 | 214 |
| 226 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, | 215 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, |
| 227 base::Bind(&PluginPrefs::OnUpdatePreferences, this, | 216 base::Bind(&PluginPrefs::OnUpdatePreferences, this, plugins)); |
| 228 plugins, plugin_finder)); | |
| 229 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, | 217 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, |
| 230 base::Bind(&PluginPrefs::NotifyPluginStatusChanged, this)); | 218 base::Bind(&PluginPrefs::NotifyPluginStatusChanged, this)); |
| 231 callback.Run(true); | 219 callback.Run(true); |
| 232 } | 220 } |
| 233 | 221 |
| 234 PluginPrefs::PolicyStatus PluginPrefs::PolicyStatusForPlugin( | 222 PluginPrefs::PolicyStatus PluginPrefs::PolicyStatusForPlugin( |
| 235 const string16& name) const { | 223 const string16& name) const { |
| 236 base::AutoLock auto_lock(lock_); | 224 base::AutoLock auto_lock(lock_); |
| 237 if (IsStringMatchedInSet(name, policy_enabled_plugin_patterns_)) { | 225 if (IsStringMatchedInSet(name, policy_enabled_plugin_patterns_)) { |
| 238 return POLICY_ENABLED; | 226 return POLICY_ENABLED; |
| 239 } else if (IsStringMatchedInSet(name, policy_disabled_plugin_patterns_) && | 227 } else if (IsStringMatchedInSet(name, policy_disabled_plugin_patterns_) && |
| 240 !IsStringMatchedInSet( | 228 !IsStringMatchedInSet( |
| 241 name, policy_disabled_plugin_exception_patterns_)) { | 229 name, policy_disabled_plugin_exception_patterns_)) { |
| 242 return POLICY_DISABLED; | 230 return POLICY_DISABLED; |
| 243 } else { | 231 } else { |
| 244 return NO_POLICY; | 232 return NO_POLICY; |
| 245 } | 233 } |
| 246 } | 234 } |
| 247 | 235 |
| 248 bool PluginPrefs::IsPluginEnabled(const webkit::WebPluginInfo& plugin) const { | 236 bool PluginPrefs::IsPluginEnabled(const webkit::WebPluginInfo& plugin) const { |
| 249 scoped_ptr<webkit::npapi::PluginGroup> group( | 237 PluginFinder* finder = PluginFinder::GetInstance(); |
| 250 GetPluginList()->GetPluginGroup(plugin)); | 238 string16 group_name = finder->GetPluginMetadata(plugin)->name(); |
| 251 string16 group_name = group->GetGroupName(); | |
| 252 | 239 |
| 253 // Check if the plug-in or its group is enabled by policy. | 240 // Check if the plug-in or its group is enabled by policy. |
| 254 PolicyStatus plugin_status = PolicyStatusForPlugin(plugin.name); | 241 PolicyStatus plugin_status = PolicyStatusForPlugin(plugin.name); |
| 255 PolicyStatus group_status = PolicyStatusForPlugin(group_name); | 242 PolicyStatus group_status = PolicyStatusForPlugin(group_name); |
| 256 if (plugin_status == POLICY_ENABLED || group_status == POLICY_ENABLED) | 243 if (plugin_status == POLICY_ENABLED || group_status == POLICY_ENABLED) |
| 257 return true; | 244 return true; |
| 258 | 245 |
| 259 // Check if the plug-in or its group is disabled by policy. | 246 // Check if the plug-in or its group is disabled by policy. |
| 260 if (plugin_status == POLICY_DISABLED || group_status == POLICY_DISABLED) | 247 if (plugin_status == POLICY_DISABLED || group_status == POLICY_DISABLED) |
| 261 return false; | 248 return false; |
| (...skipping 322 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 584 policy_enabled_plugin_patterns_ = enabled_patterns; | 571 policy_enabled_plugin_patterns_ = enabled_patterns; |
| 585 } | 572 } |
| 586 | 573 |
| 587 webkit::npapi::PluginList* PluginPrefs::GetPluginList() const { | 574 webkit::npapi::PluginList* PluginPrefs::GetPluginList() const { |
| 588 if (plugin_list_) | 575 if (plugin_list_) |
| 589 return plugin_list_; | 576 return plugin_list_; |
| 590 return PluginService::GetInstance()->GetPluginList(); | 577 return PluginService::GetInstance()->GetPluginList(); |
| 591 } | 578 } |
| 592 | 579 |
| 593 void PluginPrefs::GetPreferencesDataOnFileThread() { | 580 void PluginPrefs::GetPreferencesDataOnFileThread() { |
| 594 PluginFinder::Get( | |
| 595 base::Bind(&PluginPrefs::GetPluginFinderForGetPreferencesDataOnFileThread, | |
| 596 this)); | |
| 597 } | |
| 598 | |
| 599 void PluginPrefs::GetPluginFinderForGetPreferencesDataOnFileThread( | |
| 600 PluginFinder* finder) { | |
| 601 std::vector<webkit::WebPluginInfo> plugins; | 581 std::vector<webkit::WebPluginInfo> plugins; |
| 602 webkit::npapi::PluginList* plugin_list = GetPluginList(); | 582 webkit::npapi::PluginList* plugin_list = GetPluginList(); |
| 603 plugin_list->GetPluginsNoRefresh(&plugins); | 583 plugin_list->GetPluginsNoRefresh(&plugins); |
| 604 | 584 |
| 605 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, | 585 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, |
| 606 base::Bind(&PluginPrefs::OnUpdatePreferences, this, plugins, finder)); | 586 base::Bind(&PluginPrefs::OnUpdatePreferences, this, plugins)); |
| 607 } | 587 } |
| 608 | 588 |
| 609 void PluginPrefs::OnUpdatePreferences( | 589 void PluginPrefs::OnUpdatePreferences( |
| 610 const std::vector<webkit::WebPluginInfo>& plugins, | 590 const std::vector<webkit::WebPluginInfo>& plugins) { |
| 611 PluginFinder* finder) { | |
| 612 if (!prefs_) | 591 if (!prefs_) |
| 613 return; | 592 return; |
| 614 | 593 |
| 594 PluginFinder* finder = PluginFinder::GetInstance(); |
| 615 ListPrefUpdate update(prefs_, prefs::kPluginsPluginsList); | 595 ListPrefUpdate update(prefs_, prefs::kPluginsPluginsList); |
| 616 ListValue* plugins_list = update.Get(); | 596 ListValue* plugins_list = update.Get(); |
| 617 plugins_list->Clear(); | 597 plugins_list->Clear(); |
| 618 | 598 |
| 619 FilePath internal_dir; | 599 FilePath internal_dir; |
| 620 if (PathService::Get(chrome::DIR_INTERNAL_PLUGINS, &internal_dir)) | 600 if (PathService::Get(chrome::DIR_INTERNAL_PLUGINS, &internal_dir)) |
| 621 prefs_->SetFilePath(prefs::kPluginsLastInternalDirectory, internal_dir); | 601 prefs_->SetFilePath(prefs::kPluginsLastInternalDirectory, internal_dir); |
| 622 | 602 |
| 623 base::AutoLock auto_lock(lock_); | 603 base::AutoLock auto_lock(lock_); |
| 624 | 604 |
| 625 // Add the plugin files. | 605 // Add the plugin files. |
| 626 std::set<string16> group_names; | 606 std::set<string16> group_names; |
| 627 for (size_t i = 0; i < plugins.size(); ++i) { | 607 for (size_t i = 0; i < plugins.size(); ++i) { |
| 628 DictionaryValue* summary = new DictionaryValue(); | 608 DictionaryValue* summary = new DictionaryValue(); |
| 629 summary->SetString("path", plugins[i].path.value()); | 609 summary->SetString("path", plugins[i].path.value()); |
| 630 summary->SetString("name", plugins[i].name); | 610 summary->SetString("name", plugins[i].name); |
| 631 summary->SetString("version", plugins[i].version); | 611 summary->SetString("version", plugins[i].version); |
| 632 bool enabled = true; | 612 bool enabled = true; |
| 633 plugin_state_.Get(plugins[i].path, &enabled); | 613 plugin_state_.Get(plugins[i].path, &enabled); |
| 634 summary->SetBoolean("enabled", enabled); | 614 summary->SetBoolean("enabled", enabled); |
| 635 plugins_list->Append(summary); | 615 plugins_list->Append(summary); |
| 636 | 616 |
| 637 PluginInstaller* installer = finder->GetPluginInstaller(plugins[i]); | 617 PluginMetadata* plugin_metadata = finder->GetPluginMetadata(plugins[i]); |
| 638 // Insert into a set of all group names. | 618 // Insert into a set of all group names. |
| 639 group_names.insert(installer->name()); | 619 group_names.insert(plugin_metadata->name()); |
| 640 } | 620 } |
| 641 | 621 |
| 642 // Add the plug-in groups. | 622 // Add the plug-in groups. |
| 643 for (std::set<string16>::const_iterator it = group_names.begin(); | 623 for (std::set<string16>::const_iterator it = group_names.begin(); |
| 644 it != group_names.end(); ++it) { | 624 it != group_names.end(); ++it) { |
| 645 DictionaryValue* summary = new DictionaryValue(); | 625 DictionaryValue* summary = new DictionaryValue(); |
| 646 summary->SetString("name", *it); | 626 summary->SetString("name", *it); |
| 647 bool enabled = true; | 627 bool enabled = true; |
| 648 std::map<string16, bool>::iterator gstate_it = | 628 std::map<string16, bool>::iterator gstate_it = |
| 649 plugin_group_state_.find(*it); | 629 plugin_group_state_.find(*it); |
| 650 if (gstate_it != plugin_group_state_.end()) | 630 if (gstate_it != plugin_group_state_.end()) |
| 651 enabled = gstate_it->second; | 631 enabled = gstate_it->second; |
| 652 summary->SetBoolean("enabled", enabled); | 632 summary->SetBoolean("enabled", enabled); |
| 653 plugins_list->Append(summary); | 633 plugins_list->Append(summary); |
| 654 } | 634 } |
| 655 } | 635 } |
| 656 | 636 |
| 657 void PluginPrefs::NotifyPluginStatusChanged() { | 637 void PluginPrefs::NotifyPluginStatusChanged() { |
| 658 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 638 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 659 content::NotificationService::current()->Notify( | 639 content::NotificationService::current()->Notify( |
| 660 chrome::NOTIFICATION_PLUGIN_ENABLE_STATUS_CHANGED, | 640 chrome::NOTIFICATION_PLUGIN_ENABLE_STATUS_CHANGED, |
| 661 content::Source<Profile>(profile_), | 641 content::Source<Profile>(profile_), |
| 662 content::NotificationService::NoDetails()); | 642 content::NotificationService::NoDetails()); |
| 663 } | 643 } |
| OLD | NEW |