|  | // Copyright 2014 The Chromium OS 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 BUFFET_STATES_STATE_MANAGER_H_ | 
|  | #define BUFFET_STATES_STATE_MANAGER_H_ | 
|  |  | 
|  | #include <map> | 
|  | #include <memory> | 
|  | #include <set> | 
|  | #include <string> | 
|  | #include <vector> | 
|  |  | 
|  | #include <base/macros.h> | 
|  | #include <chromeos/errors/error.h> | 
|  | #include <chromeos/variant_dictionary.h> | 
|  |  | 
|  | #include "buffet/states/state_change_queue_interface.h" | 
|  | #include "buffet/states/state_package.h" | 
|  |  | 
|  | namespace base { | 
|  | class DictionaryValue; | 
|  | class FilePath; | 
|  | class Time; | 
|  | }  // namespace base | 
|  |  | 
|  | namespace buffet { | 
|  |  | 
|  | // StateManager is the class that aggregates the device state fragments | 
|  | // provided by device daemons and makes the aggregate device state available | 
|  | // to the GCD cloud server and local clients. | 
|  | class StateManager final { | 
|  | public: | 
|  | explicit StateManager(StateChangeQueueInterface* state_change_queue); | 
|  |  | 
|  | // Initializes the state manager and load device state fragments. | 
|  | // Called by Buffet daemon at startup. | 
|  | void Startup(); | 
|  |  | 
|  | // Returns aggregated state properties across all registered packages as | 
|  | // a JSON object that can be used to send the device state to the GCD server. | 
|  | std::unique_ptr<base::DictionaryValue> GetStateValuesAsJson( | 
|  | chromeos::ErrorPtr* error) const; | 
|  |  | 
|  | // Updates a single property value. |full_property_name| must be the full | 
|  | // name of the property to update in format "package.property". | 
|  | bool SetPropertyValue(const std::string& full_property_name, | 
|  | const chromeos::Any& value, | 
|  | const base::Time& timestamp, | 
|  | chromeos::ErrorPtr* error); | 
|  |  | 
|  | // Returns all the categories the state properties are registered from. | 
|  | // As with GCD command handling, the category normally represent a device | 
|  | // service (daemon) that is responsible for a set of properties. | 
|  | const std::set<std::string>& GetCategories() const { | 
|  | return categories_; | 
|  | } | 
|  |  | 
|  | // Returns the recorded state changes since last time this method has been | 
|  | // called. | 
|  | std::vector<StateChange> GetAndClearRecordedStateChanges(); | 
|  |  | 
|  | private: | 
|  | // Loads a device state fragment from a JSON object. |category| represents | 
|  | // a device daemon providing the state fragment or empty string for the | 
|  | // base state fragment. | 
|  | bool LoadStateDefinition(const base::DictionaryValue& json, | 
|  | const std::string& category, | 
|  | chromeos::ErrorPtr* error); | 
|  |  | 
|  | // Loads a device state fragment JSON file. The file name (without extension) | 
|  | // is used as the state fragment category. | 
|  | bool LoadStateDefinition(const base::FilePath& json_file_path, | 
|  | chromeos::ErrorPtr* error); | 
|  |  | 
|  | // Loads the base device state fragment JSON file. This state fragment | 
|  | // defines the standard state properties from the 'base' package as defined | 
|  | // by GCD specification. | 
|  | bool LoadBaseStateDefinition(const base::FilePath& json_file_path, | 
|  | chromeos::ErrorPtr* error); | 
|  |  | 
|  | // Loads state default values from JSON object. | 
|  | bool LoadStateDefaults(const base::DictionaryValue& json, | 
|  | chromeos::ErrorPtr* error); | 
|  |  | 
|  | // Loads state default values from JSON file. | 
|  | bool LoadStateDefaults(const base::FilePath& json_file_path, | 
|  | chromeos::ErrorPtr* error); | 
|  |  | 
|  | // Finds a package by its name. Returns nullptr if not found. | 
|  | StatePackage* FindPackage(const std::string& package_name); | 
|  | // Finds a package by its name. If none exists, one will be created. | 
|  | StatePackage* FindOrCreatePackage(const std::string& package_name); | 
|  |  | 
|  | StateChangeQueueInterface* state_change_queue_;  // Owned by buffet::Manager. | 
|  | std::map<std::string, std::unique_ptr<StatePackage>> packages_; | 
|  | std::set<std::string> categories_; | 
|  |  | 
|  | friend class StateManagerTest; | 
|  | DISALLOW_COPY_AND_ASSIGN(StateManager); | 
|  | }; | 
|  |  | 
|  | }  // namespace buffet | 
|  |  | 
|  | #endif  // BUFFET_STATES_STATE_MANAGER_H_ |