1 // Copyright 2014 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 EXTENSIONS_BROWSER_API_POWER_POWER_API_MANAGER_H_
6 #define EXTENSIONS_BROWSER_API_POWER_POWER_API_MANAGER_H_
11 #include "base/callback.h"
12 #include "base/memory/scoped_ptr.h"
13 #include "content/public/browser/power_save_blocker.h"
14 #include "extensions/browser/browser_context_keyed_api_factory.h"
15 #include "extensions/browser/extension_registry_observer.h"
16 #include "extensions/common/api/power.h"
22 namespace extensions
{
24 // Handles calls made via the chrome.power API. There is a separate instance of
25 // this class for each profile, as requests are tracked by extension ID, but a
26 // regular and incognito profile will share the same instance.
27 // TODO(derat): Move this to power_api.h and rename it to PowerApi.
28 class PowerApiManager
: public BrowserContextKeyedAPI
,
29 public extensions::ExtensionRegistryObserver
{
31 typedef base::Callback
<scoped_ptr
<content::PowerSaveBlocker
>(
32 content::PowerSaveBlocker::PowerSaveBlockerType
,
33 const std::string
&)> CreateBlockerFunction
;
35 static PowerApiManager
* Get(content::BrowserContext
* context
);
37 // BrowserContextKeyedAPI implementation.
38 static BrowserContextKeyedAPIFactory
<PowerApiManager
>* GetFactoryInstance();
40 // Adds an extension lock at |level| for |extension_id|, replacing the
41 // extension's existing lock, if any.
42 void AddRequest(const std::string
& extension_id
,
43 core_api::power::Level level
);
45 // Removes an extension lock for an extension. Calling this for an
46 // extension id without a lock will do nothing.
47 void RemoveRequest(const std::string
& extension_id
);
49 // Replaces the function that will be called to create PowerSaveBlocker
50 // objects. Passing an empty callback will revert to the default.
51 void SetCreateBlockerFunctionForTesting(CreateBlockerFunction function
);
53 // Overridden from extensions::ExtensionRegistryObserver.
54 void OnExtensionUnloaded(content::BrowserContext
* browser_context
,
55 const Extension
* extension
,
56 UnloadedExtensionInfo::Reason reason
) override
;
59 friend class BrowserContextKeyedAPIFactory
<PowerApiManager
>;
61 explicit PowerApiManager(content::BrowserContext
* context
);
62 ~PowerApiManager() override
;
64 // Updates |power_save_blocker_| and |current_level_| after iterating
65 // over |extension_levels_|.
66 void UpdatePowerSaveBlocker();
68 // BrowserContextKeyedAPI implementation.
69 static const char* service_name() { return "PowerApiManager"; }
70 static const bool kServiceRedirectedInIncognito
= true;
71 static const bool kServiceIsCreatedWithBrowserContext
= false;
72 void Shutdown() override
;
74 content::BrowserContext
* browser_context_
;
76 // Function that should be called to create PowerSaveBlocker objects.
77 // Tests can change this to record what would've been done instead of
78 // actually changing the system power-saving settings.
79 CreateBlockerFunction create_blocker_function_
;
81 scoped_ptr
<content::PowerSaveBlocker
> power_save_blocker_
;
83 // Current level used by |power_save_blocker_|. Meaningless if
84 // |power_save_blocker_| is NULL.
85 core_api::power::Level current_level_
;
87 // Map from extension ID to the corresponding level for each extension
88 // that has an outstanding request.
89 typedef std::map
<std::string
, core_api::power::Level
> ExtensionLevelMap
;
90 ExtensionLevelMap extension_levels_
;
92 DISALLOW_COPY_AND_ASSIGN(PowerApiManager
);
95 } // namespace extensions
97 #endif // EXTENSIONS_BROWSER_API_POWER_POWER_API_MANAGER_H_