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/extensions/api/commands/command_service.h" | 5 #include "chrome/browser/extensions/api/commands/command_service.h" |
6 | 6 |
7 #include <vector> | 7 #include <vector> |
8 | 8 |
9 #include "base/lazy_instance.h" | 9 #include "base/lazy_instance.h" |
10 #include "base/prefs/scoped_user_pref_update.h" | 10 #include "base/prefs/scoped_user_pref_update.h" |
11 #include "base/strings/string_split.h" | 11 #include "base/strings/string_split.h" |
12 #include "base/strings/string_util.h" | 12 #include "base/strings/string_util.h" |
13 #include "base/strings/utf_string_conversions.h" | 13 #include "base/strings/utf_string_conversions.h" |
14 #include "chrome/browser/chrome_notification_types.h" | 14 #include "chrome/browser/chrome_notification_types.h" |
15 #include "chrome/browser/extensions/api/commands/commands.h" | 15 #include "chrome/browser/extensions/api/commands/commands.h" |
16 #include "chrome/browser/extensions/extension_commands_global_registry.h" | 16 #include "chrome/browser/extensions/extension_commands_global_registry.h" |
17 #include "chrome/browser/extensions/extension_function_registry.h" | 17 #include "chrome/browser/extensions/extension_function_registry.h" |
18 #include "chrome/browser/extensions/extension_keybinding_registry.h" | 18 #include "chrome/browser/extensions/extension_keybinding_registry.h" |
19 #include "chrome/browser/extensions/extension_service.h" | |
20 #include "chrome/browser/profiles/profile.h" | 19 #include "chrome/browser/profiles/profile.h" |
21 #include "chrome/browser/ui/accelerator_utils.h" | 20 #include "chrome/browser/ui/accelerator_utils.h" |
22 #include "chrome/common/extensions/api/commands/commands_handler.h" | 21 #include "chrome/common/extensions/api/commands/commands_handler.h" |
23 #include "chrome/common/pref_names.h" | 22 #include "chrome/common/pref_names.h" |
24 #include "components/user_prefs/pref_registry_syncable.h" | 23 #include "components/user_prefs/pref_registry_syncable.h" |
25 #include "content/public/browser/notification_details.h" | 24 #include "content/public/browser/notification_details.h" |
26 #include "content/public/browser/notification_service.h" | 25 #include "content/public/browser/notification_service.h" |
| 26 #include "extensions/browser/extension_prefs.h" |
| 27 #include "extensions/browser/extension_registry.h" |
27 #include "extensions/browser/extension_system.h" | 28 #include "extensions/browser/extension_system.h" |
28 #include "extensions/common/feature_switch.h" | 29 #include "extensions/common/feature_switch.h" |
29 #include "extensions/common/manifest_constants.h" | 30 #include "extensions/common/manifest_constants.h" |
30 | 31 |
31 using extensions::Extension; | 32 using extensions::Extension; |
32 using extensions::ExtensionPrefs; | 33 using extensions::ExtensionPrefs; |
33 | 34 |
34 namespace { | 35 namespace { |
35 | 36 |
36 const char kExtension[] = "extension"; | 37 const char kExtension[] = "extension"; |
(...skipping 124 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
161 extensions::Command* command, | 162 extensions::Command* command, |
162 bool* active) { | 163 bool* active) { |
163 return GetExtensionActionCommand( | 164 return GetExtensionActionCommand( |
164 extension_id, type, command, active, PAGE_ACTION); | 165 extension_id, type, command, active, PAGE_ACTION); |
165 } | 166 } |
166 | 167 |
167 bool CommandService::GetNamedCommands(const std::string& extension_id, | 168 bool CommandService::GetNamedCommands(const std::string& extension_id, |
168 QueryType type, | 169 QueryType type, |
169 CommandScope scope, | 170 CommandScope scope, |
170 extensions::CommandMap* command_map) { | 171 extensions::CommandMap* command_map) { |
171 ExtensionService* extension_service = | 172 const ExtensionSet& extensions = |
172 ExtensionSystem::Get(profile_)->extension_service(); | 173 ExtensionRegistry::Get(profile_)->enabled_extensions(); |
173 if (!extension_service) | 174 const Extension* extension = extensions.GetByID(extension_id); |
174 return false; // Can occur during testing. | |
175 const ExtensionSet* extensions = extension_service->extensions(); | |
176 const Extension* extension = extensions->GetByID(extension_id); | |
177 CHECK(extension); | 175 CHECK(extension); |
178 | 176 |
179 command_map->clear(); | 177 command_map->clear(); |
180 const extensions::CommandMap* commands = | 178 const extensions::CommandMap* commands = |
181 CommandsInfo::GetNamedCommands(extension); | 179 CommandsInfo::GetNamedCommands(extension); |
182 if (!commands) | 180 if (!commands) |
183 return false; | 181 return false; |
184 | 182 |
185 extensions::CommandMap::const_iterator iter = commands->begin(); | 183 extensions::CommandMap::const_iterator iter = commands->begin(); |
186 for (; iter != commands->end(); ++iter) { | 184 for (; iter != commands->end(); ++iter) { |
(...skipping 159 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
346 | 344 |
347 return Command(); | 345 return Command(); |
348 } | 346 } |
349 | 347 |
350 void CommandService::AssignInitialKeybindings(const Extension* extension) { | 348 void CommandService::AssignInitialKeybindings(const Extension* extension) { |
351 const extensions::CommandMap* commands = | 349 const extensions::CommandMap* commands = |
352 CommandsInfo::GetNamedCommands(extension); | 350 CommandsInfo::GetNamedCommands(extension); |
353 if (!commands) | 351 if (!commands) |
354 return; | 352 return; |
355 | 353 |
356 ExtensionService* extension_service = | 354 ExtensionPrefs* extension_prefs = ExtensionPrefs::Get(profile_); |
357 ExtensionSystem::Get(profile_)->extension_service(); | |
358 ExtensionPrefs* extension_prefs = extension_service->extension_prefs(); | |
359 if (InitialBindingsHaveBeenAssigned(extension_prefs, extension->id())) | 355 if (InitialBindingsHaveBeenAssigned(extension_prefs, extension->id())) |
360 return; | 356 return; |
361 SetInitialBindingsHaveBeenAssigned(extension_prefs, extension->id()); | 357 SetInitialBindingsHaveBeenAssigned(extension_prefs, extension->id()); |
362 | 358 |
363 extensions::CommandMap::const_iterator iter = commands->begin(); | 359 extensions::CommandMap::const_iterator iter = commands->begin(); |
364 for (; iter != commands->end(); ++iter) { | 360 for (; iter != commands->end(); ++iter) { |
365 // Make sure registered Chrome shortcuts cannot be automatically assigned | 361 // Make sure registered Chrome shortcuts cannot be automatically assigned |
366 // (overwritten) by extension developers. Media keys are an exception here. | 362 // (overwritten) by extension developers. Media keys are an exception here. |
367 if ((!chrome::IsChromeAccelerator(iter->second.accelerator(), profile_) && | 363 if ((!chrome::IsChromeAccelerator(iter->second.accelerator(), profile_) && |
368 IsWhitelistedGlobalShortcut(iter->second)) || | 364 IsWhitelistedGlobalShortcut(iter->second)) || |
(...skipping 81 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
450 std::pair<const std::string, const std::string> >(&details)); | 446 std::pair<const std::string, const std::string> >(&details)); |
451 } | 447 } |
452 } | 448 } |
453 | 449 |
454 bool CommandService::GetExtensionActionCommand( | 450 bool CommandService::GetExtensionActionCommand( |
455 const std::string& extension_id, | 451 const std::string& extension_id, |
456 QueryType query_type, | 452 QueryType query_type, |
457 extensions::Command* command, | 453 extensions::Command* command, |
458 bool* active, | 454 bool* active, |
459 ExtensionActionType action_type) { | 455 ExtensionActionType action_type) { |
460 ExtensionService* service = | 456 const ExtensionSet& extensions = |
461 ExtensionSystem::Get(profile_)->extension_service(); | 457 ExtensionRegistry::Get(profile_)->enabled_extensions(); |
462 if (!service) | 458 const Extension* extension = extensions.GetByID(extension_id); |
463 return false; // Can happen in tests. | |
464 const ExtensionSet* extensions = service->extensions(); | |
465 const Extension* extension = extensions->GetByID(extension_id); | |
466 CHECK(extension); | 459 CHECK(extension); |
467 | 460 |
468 if (active) | 461 if (active) |
469 *active = false; | 462 *active = false; |
470 | 463 |
471 const extensions::Command* requested_command = NULL; | 464 const extensions::Command* requested_command = NULL; |
472 switch (action_type) { | 465 switch (action_type) { |
473 case BROWSER_ACTION: | 466 case BROWSER_ACTION: |
474 requested_command = CommandsInfo::GetBrowserActionCommand(extension); | 467 requested_command = CommandsInfo::GetBrowserActionCommand(extension); |
475 break; | 468 break; |
(...skipping 22 matching lines...) Expand all Loading... |
498 | 491 |
499 return true; | 492 return true; |
500 } | 493 } |
501 | 494 |
502 template <> | 495 template <> |
503 void ProfileKeyedAPIFactory<CommandService>::DeclareFactoryDependencies() { | 496 void ProfileKeyedAPIFactory<CommandService>::DeclareFactoryDependencies() { |
504 DependsOn(ExtensionCommandsGlobalRegistry::GetFactoryInstance()); | 497 DependsOn(ExtensionCommandsGlobalRegistry::GetFactoryInstance()); |
505 } | 498 } |
506 | 499 |
507 } // namespace extensions | 500 } // namespace extensions |
OLD | NEW |