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_API_EXTENSION_ACTION_EXTENSION_ACTION_API_H_
6 #define CHROME_BROWSER_EXTENSIONS_API_EXTENSION_ACTION_EXTENSION_ACTION_API_H_
10 #include "base/memory/weak_ptr.h"
11 #include "base/scoped_observer.h"
12 #include "chrome/browser/extensions/chrome_extension_function.h"
13 #include "chrome/browser/extensions/extension_action.h"
14 #include "content/public/browser/notification_observer.h"
15 #include "content/public/browser/notification_registrar.h"
16 #include "extensions/browser/browser_context_keyed_api_factory.h"
17 #include "extensions/browser/extension_registry_observer.h"
20 class DictionaryValue
;
28 namespace extensions
{
30 class ExtensionRegistry
;
33 class ExtensionActionAPI
: public BrowserContextKeyedAPI
{
35 explicit ExtensionActionAPI(content::BrowserContext
* context
);
36 virtual ~ExtensionActionAPI();
38 // Convenience method to get the instance for a profile.
39 static ExtensionActionAPI
* Get(content::BrowserContext
* context
);
41 static bool GetBrowserActionVisibility(const ExtensionPrefs
* prefs
,
42 const std::string
& extension_id
);
43 static void SetBrowserActionVisibility(ExtensionPrefs
* prefs
,
44 const std::string
& extension_id
,
47 // Fires the onClicked event for page_action.
48 static void PageActionExecuted(content::BrowserContext
* context
,
49 const ExtensionAction
& page_action
,
51 const std::string
& url
,
54 // Fires the onClicked event for browser_action.
55 static void BrowserActionExecuted(content::BrowserContext
* context
,
56 const ExtensionAction
& browser_action
,
57 content::WebContents
* web_contents
);
59 // BrowserContextKeyedAPI implementation.
60 static BrowserContextKeyedAPIFactory
<ExtensionActionAPI
>*
64 friend class BrowserContextKeyedAPIFactory
<ExtensionActionAPI
>;
66 // The DispatchEvent methods forward events to the |profile|'s event router.
67 static void DispatchEventToExtension(content::BrowserContext
* context
,
68 const std::string
& extension_id
,
69 const std::string
& event_name
,
70 scoped_ptr
<base::ListValue
> event_args
);
72 // Called to dispatch a deprecated style page action click event that was
74 // chrome.pageActions["name"].addListener(function(actionId, info){})
75 static void DispatchOldPageActionEvent(content::BrowserContext
* context
,
76 const std::string
& extension_id
,
77 const std::string
& page_action_id
,
79 const std::string
& url
,
82 // Called when either a browser or page action is executed. Figures out which
83 // event to send based on what the extension wants.
84 static void ExtensionActionExecuted(content::BrowserContext
* context
,
85 const ExtensionAction
& extension_action
,
86 content::WebContents
* web_contents
);
88 // BrowserContextKeyedAPI implementation.
89 static const char* service_name() { return "ExtensionActionAPI"; }
91 DISALLOW_COPY_AND_ASSIGN(ExtensionActionAPI
);
94 // This class manages reading and writing browser action values from storage.
95 class ExtensionActionStorageManager
96 : public content::NotificationObserver
,
97 public ExtensionRegistryObserver
,
98 public base::SupportsWeakPtr
<ExtensionActionStorageManager
> {
100 explicit ExtensionActionStorageManager(Profile
* profile
);
101 virtual ~ExtensionActionStorageManager();
104 // NotificationObserver:
105 virtual void Observe(int type
,
106 const content::NotificationSource
& source
,
107 const content::NotificationDetails
& details
) OVERRIDE
;
109 // ExtensionRegistryObserver:
110 virtual void OnExtensionLoaded(content::BrowserContext
* browser_context
,
111 const Extension
* extension
) OVERRIDE
;
113 // Reads/Writes the ExtensionAction's default values to/from storage.
114 void WriteToStorage(ExtensionAction
* extension_action
);
115 void ReadFromStorage(
116 const std::string
& extension_id
, scoped_ptr
<base::Value
> value
);
119 content::NotificationRegistrar registrar_
;
121 // Listen to extension loaded notification.
122 ScopedObserver
<ExtensionRegistry
, ExtensionRegistryObserver
>
123 extension_registry_observer_
;
126 // Implementation of the browserAction and pageAction APIs.
128 // Divergent behaviour between the two is minimal (pageAction has required
129 // tabIds while browserAction's are optional, they have different internal
130 // browser notification requirements, and not all functions are defined for all
132 class ExtensionActionFunction
: public ChromeSyncExtensionFunction
{
134 static bool ParseCSSColorString(const std::string
& color_string
,
138 ExtensionActionFunction();
139 virtual ~ExtensionActionFunction();
140 virtual bool RunSync() OVERRIDE
;
141 virtual bool RunExtensionAction() = 0;
143 bool ExtractDataFromArguments();
145 void NotifyBrowserActionChange();
146 void NotifyLocationBarChange();
147 void NotifySystemIndicatorChange();
148 bool SetVisible(bool visible
);
150 // Extension-related information for |tab_id_|.
151 // CHECK-fails if there is no tab.
152 extensions::TabHelper
& tab_helper() const;
154 // All the extension action APIs take a single argument called details that
156 base::DictionaryValue
* details_
;
158 // The tab id the extension action function should apply to, if any, or
159 // kDefaultTabId if none was specified.
162 // WebContents for |tab_id_| if one exists.
163 content::WebContents
* contents_
;
165 // The extension action for the current extension.
166 ExtensionAction
* extension_action_
;
170 // Implementations of each extension action API.
172 // pageAction and browserAction bindings are created for these by extending them
173 // then declaring an EXTENSION_FUNCTION_NAME.
177 class ExtensionActionShowFunction
: public ExtensionActionFunction
{
179 virtual ~ExtensionActionShowFunction() {}
180 virtual bool RunExtensionAction() OVERRIDE
;
184 class ExtensionActionHideFunction
: public ExtensionActionFunction
{
186 virtual ~ExtensionActionHideFunction() {}
187 virtual bool RunExtensionAction() OVERRIDE
;
191 class ExtensionActionSetIconFunction
: public ExtensionActionFunction
{
193 virtual ~ExtensionActionSetIconFunction() {}
194 virtual bool RunExtensionAction() OVERRIDE
;
198 class ExtensionActionSetTitleFunction
: public ExtensionActionFunction
{
200 virtual ~ExtensionActionSetTitleFunction() {}
201 virtual bool RunExtensionAction() OVERRIDE
;
205 class ExtensionActionSetPopupFunction
: public ExtensionActionFunction
{
207 virtual ~ExtensionActionSetPopupFunction() {}
208 virtual bool RunExtensionAction() OVERRIDE
;
212 class ExtensionActionSetBadgeTextFunction
: public ExtensionActionFunction
{
214 virtual ~ExtensionActionSetBadgeTextFunction() {}
215 virtual bool RunExtensionAction() OVERRIDE
;
218 // setBadgeBackgroundColor
219 class ExtensionActionSetBadgeBackgroundColorFunction
220 : public ExtensionActionFunction
{
222 virtual ~ExtensionActionSetBadgeBackgroundColorFunction() {}
223 virtual bool RunExtensionAction() OVERRIDE
;
227 class ExtensionActionGetTitleFunction
: public ExtensionActionFunction
{
229 virtual ~ExtensionActionGetTitleFunction() {}
230 virtual bool RunExtensionAction() OVERRIDE
;
234 class ExtensionActionGetPopupFunction
: public ExtensionActionFunction
{
236 virtual ~ExtensionActionGetPopupFunction() {}
237 virtual bool RunExtensionAction() OVERRIDE
;
241 class ExtensionActionGetBadgeTextFunction
: public ExtensionActionFunction
{
243 virtual ~ExtensionActionGetBadgeTextFunction() {}
244 virtual bool RunExtensionAction() OVERRIDE
;
247 // getBadgeBackgroundColor
248 class ExtensionActionGetBadgeBackgroundColorFunction
249 : public ExtensionActionFunction
{
251 virtual ~ExtensionActionGetBadgeBackgroundColorFunction() {}
252 virtual bool RunExtensionAction() OVERRIDE
;
256 // browserAction.* aliases for supported browserAction APIs.
259 class BrowserActionSetIconFunction
: public ExtensionActionSetIconFunction
{
261 DECLARE_EXTENSION_FUNCTION("browserAction.setIcon", BROWSERACTION_SETICON
)
264 virtual ~BrowserActionSetIconFunction() {}
267 class BrowserActionSetTitleFunction
: public ExtensionActionSetTitleFunction
{
269 DECLARE_EXTENSION_FUNCTION("browserAction.setTitle", BROWSERACTION_SETTITLE
)
272 virtual ~BrowserActionSetTitleFunction() {}
275 class BrowserActionSetPopupFunction
: public ExtensionActionSetPopupFunction
{
277 DECLARE_EXTENSION_FUNCTION("browserAction.setPopup", BROWSERACTION_SETPOPUP
)
280 virtual ~BrowserActionSetPopupFunction() {}
283 class BrowserActionGetTitleFunction
: public ExtensionActionGetTitleFunction
{
285 DECLARE_EXTENSION_FUNCTION("browserAction.getTitle", BROWSERACTION_GETTITLE
)
288 virtual ~BrowserActionGetTitleFunction() {}
291 class BrowserActionGetPopupFunction
: public ExtensionActionGetPopupFunction
{
293 DECLARE_EXTENSION_FUNCTION("browserAction.getPopup", BROWSERACTION_GETPOPUP
)
296 virtual ~BrowserActionGetPopupFunction() {}
299 class BrowserActionSetBadgeTextFunction
300 : public ExtensionActionSetBadgeTextFunction
{
302 DECLARE_EXTENSION_FUNCTION("browserAction.setBadgeText",
303 BROWSERACTION_SETBADGETEXT
)
306 virtual ~BrowserActionSetBadgeTextFunction() {}
309 class BrowserActionSetBadgeBackgroundColorFunction
310 : public ExtensionActionSetBadgeBackgroundColorFunction
{
312 DECLARE_EXTENSION_FUNCTION("browserAction.setBadgeBackgroundColor",
313 BROWSERACTION_SETBADGEBACKGROUNDCOLOR
)
316 virtual ~BrowserActionSetBadgeBackgroundColorFunction() {}
319 class BrowserActionGetBadgeTextFunction
320 : public ExtensionActionGetBadgeTextFunction
{
322 DECLARE_EXTENSION_FUNCTION("browserAction.getBadgeText",
323 BROWSERACTION_GETBADGETEXT
)
326 virtual ~BrowserActionGetBadgeTextFunction() {}
329 class BrowserActionGetBadgeBackgroundColorFunction
330 : public ExtensionActionGetBadgeBackgroundColorFunction
{
332 DECLARE_EXTENSION_FUNCTION("browserAction.getBadgeBackgroundColor",
333 BROWSERACTION_GETBADGEBACKGROUNDCOLOR
)
336 virtual ~BrowserActionGetBadgeBackgroundColorFunction() {}
339 class BrowserActionEnableFunction
: public ExtensionActionShowFunction
{
341 DECLARE_EXTENSION_FUNCTION("browserAction.enable", BROWSERACTION_ENABLE
)
344 virtual ~BrowserActionEnableFunction() {}
347 class BrowserActionDisableFunction
: public ExtensionActionHideFunction
{
349 DECLARE_EXTENSION_FUNCTION("browserAction.disable", BROWSERACTION_DISABLE
)
352 virtual ~BrowserActionDisableFunction() {}
355 class BrowserActionOpenPopupFunction
: public ChromeAsyncExtensionFunction
,
356 public content::NotificationObserver
{
358 DECLARE_EXTENSION_FUNCTION("browserAction.openPopup",
359 BROWSERACTION_OPEN_POPUP
)
360 BrowserActionOpenPopupFunction();
363 virtual ~BrowserActionOpenPopupFunction() {}
365 // ExtensionFunction:
366 virtual bool RunImpl() OVERRIDE
;
368 virtual void Observe(int type
,
369 const content::NotificationSource
& source
,
370 const content::NotificationDetails
& details
) OVERRIDE
;
371 void OpenPopupTimedOut();
373 content::NotificationRegistrar registrar_
;
376 DISALLOW_COPY_AND_ASSIGN(BrowserActionOpenPopupFunction
);
379 } // namespace extensions
382 // pageAction.* aliases for supported pageAction APIs.
385 class PageActionShowFunction
: public extensions::ExtensionActionShowFunction
{
387 DECLARE_EXTENSION_FUNCTION("pageAction.show", PAGEACTION_SHOW
)
390 virtual ~PageActionShowFunction() {}
393 class PageActionHideFunction
: public extensions::ExtensionActionHideFunction
{
395 DECLARE_EXTENSION_FUNCTION("pageAction.hide", PAGEACTION_HIDE
)
398 virtual ~PageActionHideFunction() {}
401 class PageActionSetIconFunction
402 : public extensions::ExtensionActionSetIconFunction
{
404 DECLARE_EXTENSION_FUNCTION("pageAction.setIcon", PAGEACTION_SETICON
)
407 virtual ~PageActionSetIconFunction() {}
410 class PageActionSetTitleFunction
411 : public extensions::ExtensionActionSetTitleFunction
{
413 DECLARE_EXTENSION_FUNCTION("pageAction.setTitle", PAGEACTION_SETTITLE
)
416 virtual ~PageActionSetTitleFunction() {}
419 class PageActionSetPopupFunction
420 : public extensions::ExtensionActionSetPopupFunction
{
422 DECLARE_EXTENSION_FUNCTION("pageAction.setPopup", PAGEACTION_SETPOPUP
)
425 virtual ~PageActionSetPopupFunction() {}
428 class PageActionGetTitleFunction
429 : public extensions::ExtensionActionGetTitleFunction
{
431 DECLARE_EXTENSION_FUNCTION("pageAction.getTitle", PAGEACTION_GETTITLE
)
434 virtual ~PageActionGetTitleFunction() {}
437 class PageActionGetPopupFunction
438 : public extensions::ExtensionActionGetPopupFunction
{
440 DECLARE_EXTENSION_FUNCTION("pageAction.getPopup", PAGEACTION_GETPOPUP
)
443 virtual ~PageActionGetPopupFunction() {}
446 // Base class for deprecated page actions APIs
447 class PageActionsFunction
: public ChromeSyncExtensionFunction
{
449 PageActionsFunction();
450 virtual ~PageActionsFunction();
451 bool SetPageActionEnabled(bool enable
);
454 // Implement chrome.pageActions.enableForTab().
455 class EnablePageActionsFunction
: public PageActionsFunction
{
457 DECLARE_EXTENSION_FUNCTION("pageActions.enableForTab",
458 PAGEACTIONS_ENABLEFORTAB
)
461 virtual ~EnablePageActionsFunction() {}
463 // ExtensionFunction:
464 virtual bool RunSync() OVERRIDE
;
467 // Implement chrome.pageActions.disableForTab().
468 class DisablePageActionsFunction
: public PageActionsFunction
{
470 DECLARE_EXTENSION_FUNCTION("pageActions.disableForTab",
471 PAGEACTIONS_DISABLEFORTAB
)
474 virtual ~DisablePageActionsFunction() {}
476 // ExtensionFunction:
477 virtual bool RunSync() OVERRIDE
;
480 #endif // CHROME_BROWSER_EXTENSIONS_API_EXTENSION_ACTION_EXTENSION_ACTION_API_H_