Home | History | Annotate | Download | only in network
      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.
      4 
      5 #ifndef CHROMEOS_NETWORK_MANAGED_STATE_H_
      6 #define CHROMEOS_NETWORK_MANAGED_STATE_H_
      7 
      8 #include <string>
      9 
     10 #include "base/basictypes.h"
     11 #include "base/compiler_specific.h"
     12 #include "chromeos/chromeos_export.h"
     13 
     14 namespace base {
     15 class Value;
     16 class DictionaryValue;
     17 }
     18 
     19 namespace chromeos {
     20 
     21 class DeviceState;
     22 class NetworkState;
     23 class NetworkTypePattern;
     24 
     25 // Base class for states managed by NetworkStateManger which are associated
     26 // with a Shill path (e.g. service path or device path).
     27 class CHROMEOS_EXPORT ManagedState {
     28  public:
     29   enum ManagedType {
     30     MANAGED_TYPE_NETWORK,
     31     MANAGED_TYPE_DEVICE
     32   };
     33 
     34   virtual ~ManagedState();
     35 
     36   // This will construct and return a new instance of the appropriate class
     37   // based on |type|.
     38   static ManagedState* Create(ManagedType type, const std::string& path);
     39 
     40   // Returns the specific class pointer if this is the correct type, or
     41   // NULL if it is not.
     42   NetworkState* AsNetworkState();
     43   DeviceState* AsDeviceState();
     44 
     45   // Called by NetworkStateHandler when a property was received. The return
     46   // value indicates if the state changed and is used to reduce the number of
     47   // notifications. The only guarantee however is: If the return value is false
     48   // then the state wasn't modified. This might happen because of
     49   // * |key| was not recognized.
     50   // * |value| was not parsed successfully.
     51   // * |value| is equal to the cached property value.
     52   // If the return value is true, the state might or might not be modified.
     53   virtual bool PropertyChanged(const std::string& key,
     54                                const base::Value& value) = 0;
     55 
     56   // Called by NetworkStateHandler after all calls to PropertyChanged for the
     57   // initial set of properties. Used to update state requiring multiple
     58   // properties, e.g. name from hex_ssid in NetworkState.
     59   // |properties| contains the complete set of initial properties.
     60   // Returns true if any additional properties are updated.
     61   virtual bool InitialPropertiesReceived(
     62       const base::DictionaryValue& properties);
     63 
     64   // Fills |dictionary| with a minimal set of state properties for the network
     65   // type. See implementations for which properties are included.
     66   virtual void GetStateProperties(base::DictionaryValue* dictionary) const;
     67 
     68   const ManagedType managed_type() const { return managed_type_; }
     69   const std::string& path() const { return path_; }
     70   const std::string& name() const { return name_; }
     71   const std::string& type() const { return type_; }
     72   bool update_received() const { return update_received_; }
     73   void set_update_received() { update_received_ = true; }
     74   bool update_requested() const { return update_requested_; }
     75   void set_update_requested(bool update_requested) {
     76     update_requested_ = update_requested;
     77   }
     78 
     79   // Returns true if |type_| matches |pattern|.
     80   bool Matches(const NetworkTypePattern& pattern) const;
     81 
     82   static std::string TypeToString(ManagedType type);
     83 
     84  protected:
     85   ManagedState(ManagedType type, const std::string& path);
     86 
     87   // Parses common property keys (name, type).
     88   bool ManagedStatePropertyChanged(const std::string& key,
     89                                    const base::Value& value);
     90 
     91   // Helper methods that log warnings and return true if parsing succeeded and
     92   // the new value does not match the existing output value.
     93   bool GetBooleanValue(const std::string& key,
     94                        const base::Value& value,
     95                        bool* out_value);
     96   bool GetIntegerValue(const std::string& key,
     97                        const base::Value& value,
     98                        int* out_value);
     99   bool GetStringValue(const std::string& key,
    100                       const base::Value& value,
    101                       std::string* out_value);
    102   bool GetUInt32Value(const std::string& key,
    103                       const base::Value& value,
    104                       uint32* out_value);
    105 
    106   void set_name(const std::string& name) { name_ = name; }
    107 
    108  private:
    109   friend class NetworkChangeNotifierChromeosUpdateTest;
    110 
    111   ManagedType managed_type_;
    112 
    113   // The path (e.g. service path or device path) of the managed state object.
    114   std::string path_;
    115 
    116   // Common properties shared by all managed state objects.
    117   std::string name_;  // shill::kNameProperty
    118   std::string type_;  // shill::kTypeProperty
    119 
    120   // Set to true when the an update has been received.
    121   bool update_received_;
    122 
    123   // Tracks when an update has been requested.
    124   bool update_requested_;
    125 
    126   DISALLOW_COPY_AND_ASSIGN(ManagedState);
    127 };
    128 
    129 }  // namespace chromeos
    130 
    131 #endif  // CHROMEOS_NETWORK_MANAGED_STATE_H_
    132