Updating trunk VERSION from 2139.0 to 2140.0
[chromium-blink-merge.git] / chromeos / dbus / power_policy_controller.h
blob4939a00a5faa0b45cb4cf5f015093eebbe5cf9cc
1 // Copyright (c) 2013 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 CHROMEOS_DBUS_POWER_POLICY_CONTROLLER_H_
6 #define CHROMEOS_DBUS_POWER_POLICY_CONTROLLER_H_
8 #include <map>
9 #include <string>
11 #include "base/basictypes.h"
12 #include "base/compiler_specific.h"
13 #include "chromeos/chromeos_export.h"
14 #include "chromeos/dbus/power_manager/policy.pb.h"
15 #include "chromeos/dbus/power_manager_client.h"
17 namespace chromeos {
19 class DBusThreadManager;
21 // PowerPolicyController is responsible for sending Chrome's assorted power
22 // management preferences to the Chrome OS power manager.
23 class CHROMEOS_EXPORT PowerPolicyController
24 : public PowerManagerClient::Observer {
25 public:
26 // Note: Do not change these values; they are used by preferences.
27 enum Action {
28 ACTION_SUSPEND = 0,
29 ACTION_STOP_SESSION = 1,
30 ACTION_SHUT_DOWN = 2,
31 ACTION_DO_NOTHING = 3,
34 // Values of various power-management-related preferences.
35 struct PrefValues {
36 PrefValues();
38 int ac_screen_dim_delay_ms;
39 int ac_screen_off_delay_ms;
40 int ac_screen_lock_delay_ms;
41 int ac_idle_warning_delay_ms;
42 int ac_idle_delay_ms;
43 int battery_screen_dim_delay_ms;
44 int battery_screen_off_delay_ms;
45 int battery_screen_lock_delay_ms;
46 int battery_idle_warning_delay_ms;
47 int battery_idle_delay_ms;
48 Action ac_idle_action;
49 Action battery_idle_action;
50 Action lid_closed_action;
51 bool use_audio_activity;
52 bool use_video_activity;
53 double ac_brightness_percent;
54 double battery_brightness_percent;
55 bool allow_screen_wake_locks;
56 bool enable_auto_screen_lock;
57 double presentation_screen_dim_delay_factor;
58 double user_activity_screen_dim_delay_factor;
59 bool wait_for_initial_user_activity;
62 // Returns a string describing |policy|. Useful for tests.
63 static std::string GetPolicyDebugString(
64 const power_manager::PowerManagementPolicy& policy);
66 // Delay in milliseconds between the screen being turned off and the screen
67 // being locked. Used if the |enable_auto_screen_lock| pref is set but
68 // |*_screen_lock_delay_ms| are unset or set to higher values than what this
69 // constant would imply.
70 static const int kScreenLockAfterOffDelayMs;
72 PowerPolicyController();
73 virtual ~PowerPolicyController();
75 void Init(DBusThreadManager* manager);
77 // Updates |prefs_policy_| with |values| and sends an updated policy.
78 void ApplyPrefs(const PrefValues& values);
80 // Registers a request to temporarily prevent the screen from getting
81 // dimmed or turned off or the system from suspending in response to user
82 // inactivity and sends an updated policy. |reason| is a human-readable
83 // description of the reason the lock was created. Returns a unique ID
84 // that can be passed to RemoveWakeLock() later.
85 int AddScreenWakeLock(const std::string& reason);
86 int AddSystemWakeLock(const std::string& reason);
88 // Unregisters a request previously created via AddScreenWakeLock() or
89 // AddSystemWakeLock() and sends an updated policy.
90 void RemoveWakeLock(int id);
92 // PowerManagerClient::Observer implementation:
93 virtual void PowerManagerRestarted() OVERRIDE;
95 private:
96 friend class PowerPrefsTest;
98 typedef std::map<int, std::string> WakeLockMap;
100 // Sends a policy based on |prefs_policy_| to the power manager.
101 void SendCurrentPolicy();
103 PowerManagerClient* client_; // weak
105 // Policy derived from values passed to ApplyPrefs().
106 power_manager::PowerManagementPolicy prefs_policy_;
108 // Was ApplyPrefs() called?
109 bool prefs_were_set_;
111 // Maps from an ID representing a request to prevent the screen from
112 // getting dimmed or turned off or to prevent the system from suspending
113 // to the reason for the request.
114 WakeLockMap screen_wake_locks_;
115 WakeLockMap system_wake_locks_;
117 // Should entries in |screen_wake_locks_| be honored? If false, screen
118 // wake locks are just treated as system wake locks instead.
119 bool honor_screen_wake_locks_;
121 // Next ID to be used by AddScreenWakeLock() or AddSystemWakeLock().
122 int next_wake_lock_id_;
124 DISALLOW_COPY_AND_ASSIGN(PowerPolicyController);
127 } // namespace chromeos
129 #endif // CHROMEOS_DBUS_POWER_POLICY_CONTROLLER_H_