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
3 // found in the LICENSE file.
5 #ifndef CHROME_BROWSER_EXTENSIONS_EXTENSION_ACTION_MANAGER_H_
6 #define CHROME_BROWSER_EXTENSIONS_EXTENSION_ACTION_MANAGER_H_
11 #include "base/scoped_observer.h"
12 #include "chrome/common/extensions/api/extension_action/action_info.h"
13 #include "components/keyed_service/core/keyed_service.h"
14 #include "extensions/browser/extension_registry_observer.h"
16 class ExtensionAction
;
19 namespace extensions
{
22 class ExtensionRegistry
;
24 // Owns the ExtensionActions associated with each extension. These actions live
25 // while an extension is loaded and are destroyed on unload.
26 class ExtensionActionManager
: public KeyedService
,
27 public ExtensionRegistryObserver
{
29 explicit ExtensionActionManager(Profile
* profile
);
30 ~ExtensionActionManager() override
;
32 // Returns this profile's ExtensionActionManager. One instance is
33 // shared between a profile and its incognito version.
34 static ExtensionActionManager
* Get(content::BrowserContext
* browser_context
);
36 // Retrieves the page action, browser action, or system indicator for
38 // If the result is not NULL, it remains valid until the extension is
40 ExtensionAction
* GetPageAction(const Extension
& extension
) const;
41 ExtensionAction
* GetBrowserAction(const Extension
& extension
) const;
42 ExtensionAction
* GetSystemIndicator(const Extension
& extension
) const;
44 // Returns either the PageAction or BrowserAction for |extension|, or NULL if
45 // none exists. Since an extension can only declare one of Browser|PageAction,
46 // this is okay to use anywhere you need a generic "ExtensionAction".
47 // Since SystemIndicators are used differently and don't follow this
48 // rule of mutual exclusion, they are not checked or returned.
49 ExtensionAction
* GetExtensionAction(const Extension
& extension
) const;
51 // Gets the best fit ExtensionAction for the given |extension|. This takes
52 // into account |extension|'s browser or page actions, if any, along with its
53 // name and any declared icons.
54 scoped_ptr
<ExtensionAction
> GetBestFitAction(
55 const Extension
& extension
, ActionInfo::Type type
) const;
58 // Implement ExtensionRegistryObserver.
59 void OnExtensionUnloaded(content::BrowserContext
* browser_context
,
60 const Extension
* extension
,
61 UnloadedExtensionInfo::Reason reason
) override
;
65 // Listen to extension unloaded notifications.
66 ScopedObserver
<ExtensionRegistry
, ExtensionRegistryObserver
>
67 extension_registry_observer_
;
69 // Keyed by Extension ID. These maps are populated lazily when their
70 // ExtensionAction is first requested, and the entries are removed when the
71 // extension is unloaded. Not every extension has a page action or browser
73 typedef std::map
<std::string
, linked_ptr
<ExtensionAction
> > ExtIdToActionMap
;
74 mutable ExtIdToActionMap page_actions_
;
75 mutable ExtIdToActionMap browser_actions_
;
76 mutable ExtIdToActionMap system_indicators_
;
79 } // namespace extensions
81 #endif // CHROME_BROWSER_EXTENSIONS_EXTENSION_ACTION_MANAGER_H_