| // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 
 | // Use of this source code is governed by a BSD-style license that can be | 
 | // found in the LICENSE file. | 
 |  | 
 | #ifndef BASE_SYSTEM_MONITOR_SYSTEM_MONITOR_H_ | 
 | #define BASE_SYSTEM_MONITOR_SYSTEM_MONITOR_H_ | 
 |  | 
 | #include <map> | 
 | #include <string> | 
 | #include <vector> | 
 |  | 
 | #include "base/base_export.h" | 
 | #include "base/basictypes.h" | 
 | #include "base/file_path.h" | 
 | #include "base/string16.h" | 
 | #include "base/synchronization/lock.h" | 
 | #include "build/build_config.h" | 
 |  | 
 | // Windows HiRes timers drain the battery faster so we need to know the battery | 
 | // status.  This isn't true for other platforms. | 
 | #if defined(OS_WIN) | 
 | #define ENABLE_BATTERY_MONITORING 1 | 
 | #else | 
 | #undef ENABLE_BATTERY_MONITORING | 
 | #endif  // !OS_WIN | 
 |  | 
 | #include "base/observer_list_threadsafe.h" | 
 | #if defined(ENABLE_BATTERY_MONITORING) | 
 | #include "base/timer.h" | 
 | #endif  // defined(ENABLE_BATTERY_MONITORING) | 
 |  | 
 | #if defined(OS_MACOSX) && !defined(OS_IOS) | 
 | #include <IOKit/pwr_mgt/IOPMLib.h> | 
 | #include <IOKit/IOMessage.h> | 
 | #endif  // OS_MACOSX && !OS_IOS | 
 |  | 
 | #if defined(OS_IOS) | 
 | #include <objc/runtime.h> | 
 | #endif  // OS_IOS | 
 |  | 
 | namespace base { | 
 |  | 
 | // Class for monitoring various system-related subsystems | 
 | // such as power management, network status, etc. | 
 | // TODO(mbelshe):  Add support beyond just power management. | 
 | class BASE_EXPORT SystemMonitor { | 
 |  public: | 
 |   // Normalized list of power events. | 
 |   enum PowerEvent { | 
 |     POWER_STATE_EVENT,  // The Power status of the system has changed. | 
 |     SUSPEND_EVENT,      // The system is being suspended. | 
 |     RESUME_EVENT        // The system is being resumed. | 
 |   }; | 
 |  | 
 |   // Type of devices whose change need to be monitored, such as add/remove. | 
 |   enum DeviceType { | 
 |     DEVTYPE_AUDIO_CAPTURE,  // Audio capture device, e.g., microphone. | 
 |     DEVTYPE_VIDEO_CAPTURE,  // Video capture device, e.g., webcam. | 
 |     DEVTYPE_UNKNOWN,  // Other devices. | 
 |   }; | 
 |  | 
 |   struct BASE_EXPORT RemovableStorageInfo { | 
 |     RemovableStorageInfo(); | 
 |     RemovableStorageInfo(const std::string& id, | 
 |                          const string16& device_name, | 
 |                          const FilePath::StringType& device_location); | 
 |  | 
 |     // Unique device id - persists between device attachments. | 
 |     std::string device_id; | 
 |  | 
 |     // Human readable removable storage device name. | 
 |     string16 name; | 
 |  | 
 |     // Current attached removable storage device location. | 
 |     FilePath::StringType location; | 
 |   }; | 
 |  | 
 |   // Create SystemMonitor. Only one SystemMonitor instance per application | 
 |   // is allowed. | 
 |   SystemMonitor(); | 
 |   ~SystemMonitor(); | 
 |  | 
 |   // Get the application-wide SystemMonitor (if not present, returns NULL). | 
 |   static SystemMonitor* Get(); | 
 |  | 
 | #if defined(OS_MACOSX) | 
 |   // Allocate system resources needed by the SystemMonitor class. | 
 |   // | 
 |   // This function must be called before instantiating an instance of the class | 
 |   // and before the Sandbox is initialized. | 
 | #if !defined(OS_IOS) | 
 |   static void AllocateSystemIOPorts(); | 
 | #else | 
 |   static void AllocateSystemIOPorts() {} | 
 | #endif  // OS_IOS | 
 | #endif  // OS_MACOSX | 
 |  | 
 |   // Returns information for attached removable storage. | 
 |   std::vector<RemovableStorageInfo> GetAttachedRemovableStorage() const; | 
 |  | 
 |   // | 
 |   // Power-related APIs | 
 |   // | 
 |  | 
 |   // Is the computer currently on battery power. | 
 |   // Can be called on any thread. | 
 |   bool BatteryPower() const { | 
 |     // Using a lock here is not necessary for just a bool. | 
 |     return battery_in_use_; | 
 |   } | 
 |  | 
 |   // Callbacks will be called on the thread which creates the SystemMonitor. | 
 |   // During the callback, Add/RemoveObserver will block until the callbacks | 
 |   // are finished. Observers should implement quick callback functions; if | 
 |   // lengthy operations are needed, the observer should take care to invoke | 
 |   // the operation on an appropriate thread. | 
 |   class BASE_EXPORT PowerObserver { | 
 |    public: | 
 |     // Notification of a change in power status of the computer, such | 
 |     // as from switching between battery and A/C power. | 
 |     virtual void OnPowerStateChange(bool /*on_battery_power*/) {} | 
 |  | 
 |     // Notification that the system is suspending. | 
 |     virtual void OnSuspend() {} | 
 |  | 
 |     // Notification that the system is resuming. | 
 |     virtual void OnResume() {} | 
 |  | 
 |    protected: | 
 |     virtual ~PowerObserver() {} | 
 |   }; | 
 |  | 
 |   class BASE_EXPORT DevicesChangedObserver { | 
 |    public: | 
 |     // Notification that the devices connected to the system have changed. | 
 |     // This is only implemented on Windows currently. | 
 |     virtual void OnDevicesChanged(DeviceType /*device_type*/) {} | 
 |  | 
 |     // When a removable storage device is attached or detached, one of these | 
 |     // two events is triggered. | 
 |     virtual void OnRemovableStorageAttached( | 
 |         const std::string& /*id*/, | 
 |         const string16& /*name*/, | 
 |         const FilePath::StringType& /*location*/) {} | 
 |     virtual void OnRemovableStorageDetached(const std::string& /*id*/) {} | 
 |  | 
 |    protected: | 
 |     virtual ~DevicesChangedObserver() {} | 
 |   }; | 
 |  | 
 |   // Add a new observer. | 
 |   // Can be called from any thread. | 
 |   // Must not be called from within a notification callback. | 
 |   void AddPowerObserver(PowerObserver* obs); | 
 |   void AddDevicesChangedObserver(DevicesChangedObserver* obs); | 
 |  | 
 |   // Remove an existing observer. | 
 |   // Can be called from any thread. | 
 |   // Must not be called from within a notification callback. | 
 |   void RemovePowerObserver(PowerObserver* obs); | 
 |   void RemoveDevicesChangedObserver(DevicesChangedObserver* obs); | 
 |  | 
 |   // The ProcessFoo() style methods are a broken pattern and should not | 
 |   // be copied. Any significant addition to this class is blocked on | 
 |   // refactoring to improve the state of affairs. See http://crbug.com/149059 | 
 |  | 
 | #if defined(OS_WIN) | 
 |   // Windows-specific handling of a WM_POWERBROADCAST message. | 
 |   // Embedders of this API should hook their top-level window | 
 |   // message loop and forward WM_POWERBROADCAST through this call. | 
 |   void ProcessWmPowerBroadcastMessage(int event_id); | 
 | #endif | 
 |  | 
 |   // Cross-platform handling of a power event. | 
 |   void ProcessPowerMessage(PowerEvent event_id); | 
 |  | 
 |   // Cross-platform handling of a device change event. | 
 |   void ProcessDevicesChanged(DeviceType device_type); | 
 |   void ProcessRemovableStorageAttached(const std::string& id, | 
 |                                        const string16& name, | 
 |                                        const FilePath::StringType& location); | 
 |   void ProcessRemovableStorageDetached(const std::string& id); | 
 |  | 
 |  private: | 
 |   // Mapping of unique device id to device info tuple. | 
 |   typedef std::map<std::string, RemovableStorageInfo> RemovableStorageMap; | 
 |  | 
 | #if defined(OS_MACOSX) | 
 |   void PlatformInit(); | 
 |   void PlatformDestroy(); | 
 | #endif | 
 |  | 
 |   // Platform-specific method to check whether the system is currently | 
 |   // running on battery power.  Returns true if running on batteries, | 
 |   // false otherwise. | 
 |   bool IsBatteryPower(); | 
 |  | 
 |   // Checks the battery status and notifies observers if the battery | 
 |   // status has changed. | 
 |   void BatteryCheck(); | 
 |  | 
 |   // Functions to trigger notifications. | 
 |   void NotifyDevicesChanged(DeviceType device_type); | 
 |   void NotifyRemovableStorageAttached(const std::string& id, | 
 |                                       const string16& name, | 
 |                                       const FilePath::StringType& location); | 
 |   void NotifyRemovableStorageDetached(const std::string& id); | 
 |   void NotifyPowerStateChange(); | 
 |   void NotifySuspend(); | 
 |   void NotifyResume(); | 
 |  | 
 |   scoped_refptr<ObserverListThreadSafe<PowerObserver> > power_observer_list_; | 
 |   scoped_refptr<ObserverListThreadSafe<DevicesChangedObserver> > | 
 |       devices_changed_observer_list_; | 
 |   bool battery_in_use_; | 
 |   bool suspended_; | 
 |  | 
 | #if defined(ENABLE_BATTERY_MONITORING) | 
 |   base::OneShotTimer<SystemMonitor> delayed_battery_check_; | 
 | #endif | 
 |  | 
 | #if defined(OS_IOS) | 
 |   // Holds pointers to system event notification observers. | 
 |   std::vector<id> notification_observers_; | 
 | #endif | 
 |  | 
 |   // For manipulating removable_storage_map_ structure. | 
 |   mutable base::Lock removable_storage_lock_; | 
 |   // Map of all the attached removable storage devices. | 
 |   RemovableStorageMap removable_storage_map_; | 
 |  | 
 |   DISALLOW_COPY_AND_ASSIGN(SystemMonitor); | 
 | }; | 
 |  | 
 | }  // namespace base | 
 |  | 
 | #endif  // BASE_SYSTEM_MONITOR_SYSTEM_MONITOR_H_ |