blob: f3c0b2e05ce2647ba3b9366be0f05672c946bb3f [file] [log] [blame]
mukesh agrawal4d0401c2012-01-06 16:05:31 -08001// Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
Chris Masoneb925cc82011-06-22 15:39:57 -07002// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef SHILL_PROPERTY_STORE_
6#define SHILL_PROPERTY_STORE_
7
8#include <map>
9#include <string>
10#include <vector>
11
12#include <base/basictypes.h>
13
14#include "shill/accessor_interface.h"
Chris Masonea8a2c252011-06-27 22:16:30 -070015#include "shill/property_iterator.h"
Chris Masoneb925cc82011-06-22 15:39:57 -070016
17namespace shill {
18
19class Error;
20
21class PropertyStore {
22 public:
Chris Masone27c4aa52011-07-02 13:10:14 -070023 PropertyStore();
Chris Masoneb925cc82011-06-22 15:39:57 -070024 virtual ~PropertyStore();
25
mukesh agrawalde29fa82011-09-16 16:16:36 -070026 virtual bool Contains(const std::string& property) const;
Chris Masoneb925cc82011-06-22 15:39:57 -070027
28 // Methods to allow the setting, by name, of properties stored in this object.
29 // The property names are declared in chromeos/dbus/service_constants.h,
30 // so that they may be shared with libcros.
31 // Upon success, these methods return true and leave |error| untouched.
32 // Upon failure, they return false and set |error| appropriately, if it
33 // is non-NULL.
mukesh agrawal66b0aca2012-01-30 15:28:28 -080034 virtual bool SetBoolProperty(const std::string &name,
Chris Masoneb925cc82011-06-22 15:39:57 -070035 bool value,
36 Error *error);
37
mukesh agrawal66b0aca2012-01-30 15:28:28 -080038 virtual bool SetInt16Property(const std::string &name,
Chris Masoneb925cc82011-06-22 15:39:57 -070039 int16 value,
40 Error *error);
41
mukesh agrawal66b0aca2012-01-30 15:28:28 -080042 virtual bool SetInt32Property(const std::string &name,
Chris Masoneb925cc82011-06-22 15:39:57 -070043 int32 value,
44 Error *error);
45
mukesh agrawal66b0aca2012-01-30 15:28:28 -080046 virtual bool SetStringProperty(const std::string &name,
47 const std::string &value,
Chris Masoneb925cc82011-06-22 15:39:57 -070048 Error *error);
49
50 virtual bool SetStringmapProperty(
mukesh agrawal66b0aca2012-01-30 15:28:28 -080051 const std::string &name,
52 const std::map<std::string, std::string> &values,
Chris Masoneb925cc82011-06-22 15:39:57 -070053 Error *error);
54
mukesh agrawal66b0aca2012-01-30 15:28:28 -080055 virtual bool SetStringsProperty(const std::string &name,
56 const std::vector<std::string> &values,
Chris Masoneb925cc82011-06-22 15:39:57 -070057 Error *error);
58
mukesh agrawal66b0aca2012-01-30 15:28:28 -080059 virtual bool SetUint8Property(const std::string &name,
Chris Masoneb925cc82011-06-22 15:39:57 -070060 uint8 value,
61 Error *error);
62
mukesh agrawal66b0aca2012-01-30 15:28:28 -080063 virtual bool SetUint16Property(const std::string &name,
Chris Masoneb925cc82011-06-22 15:39:57 -070064 uint16 value,
65 Error *error);
66
mukesh agrawal66b0aca2012-01-30 15:28:28 -080067 virtual bool SetUint32Property(const std::string &name,
Chris Masoneb925cc82011-06-22 15:39:57 -070068 uint32 value,
69 Error *error);
70
mukesh agrawal4d260da2012-01-30 11:53:52 -080071 // Clearing a property resets it to its "factory" value. This value
72 // is generally the value that it (the property) had when it was
73 // registered with PropertyStore.
74 //
75 // The exception to this rule is write-only derived properties. For
76 // such properties, the property owner explicitly provides a
77 // "factory" value at registration time. This is necessary because
78 // PropertyStore can't read the current value at registration time.
79 //
80 // |name| is the key used to access the property. If the property
81 // cannot be cleared, |error| is set, and the method returns false.
82 // Otherwrise, |error| is unchanged, and the method returns true.
83 virtual bool ClearProperty(const std::string &name, Error *error);
84
mukesh agrawalffa3d042011-10-06 15:26:10 -070085 // We do not provide methods for reading individual properties,
86 // because we don't need them to implement the flimflam API. (The flimflam
87 // API only allows fetching all properties at once -- not individual
88 // properties.)
89
90 // Accessors for iterators over property maps. Useful for dumping all
91 // properties.
Gaurav Shah1b7a6162011-11-09 11:41:01 -080092 ReadablePropertyConstIterator<bool> GetBoolPropertiesIter() const;
93 ReadablePropertyConstIterator<int16> GetInt16PropertiesIter() const;
94 ReadablePropertyConstIterator<int32> GetInt32PropertiesIter() const;
Darin Petkov63138a92012-02-06 14:09:15 +010095 ReadablePropertyConstIterator<KeyValueStore> GetKeyValueStorePropertiesIter(
96 ) const;
mukesh agrawal2366eed2012-03-20 18:21:50 -070097 ReadablePropertyConstIterator<RpcIdentifiers> GetRpcIdentifiersPropertiesIter(
98 ) const;
Gaurav Shah1b7a6162011-11-09 11:41:01 -080099 ReadablePropertyConstIterator<std::string> GetStringPropertiesIter() const;
100 ReadablePropertyConstIterator<Stringmap> GetStringmapPropertiesIter() const;
101 ReadablePropertyConstIterator<Stringmaps> GetStringmapsPropertiesIter() const;
Gaurav Shah1b7a6162011-11-09 11:41:01 -0800102 ReadablePropertyConstIterator<Strings> GetStringsPropertiesIter() const;
103 ReadablePropertyConstIterator<uint8> GetUint8PropertiesIter() const;
104 ReadablePropertyConstIterator<uint16> GetUint16PropertiesIter() const;
105 ReadablePropertyConstIterator<uint32> GetUint32PropertiesIter() const;
Chris Masonea8a2c252011-06-27 22:16:30 -0700106
mukesh agrawal4d260da2012-01-30 11:53:52 -0800107 // Methods for registering a property.
108 //
109 // It is permitted to re-register a property (in which case the old
110 // binding is forgotten). However, the newly bound object must be of
111 // the same type.
112 //
113 // Note that types do not encode read-write permission. Hence, it
114 // is possible to change permissions by rebinding a property to the
115 // same object.
116 //
117 // (Corollary of the rebinding-to-same-type restriction: a
118 // PropertyStore cannot hold two properties of the same name, but
119 // differing types.)
Chris Masoneb925cc82011-06-22 15:39:57 -0700120 void RegisterBool(const std::string &name, bool *prop);
121 void RegisterConstBool(const std::string &name, const bool *prop);
Gaurav Shah1b7a6162011-11-09 11:41:01 -0800122 void RegisterWriteOnlyBool(const std::string &name, bool *prop);
Chris Masoneb925cc82011-06-22 15:39:57 -0700123 void RegisterInt16(const std::string &name, int16 *prop);
124 void RegisterConstInt16(const std::string &name, const int16 *prop);
Gaurav Shah1b7a6162011-11-09 11:41:01 -0800125 void RegisterWriteOnlyInt16(const std::string &name, int16 *prop);
Chris Masoneb925cc82011-06-22 15:39:57 -0700126 void RegisterInt32(const std::string &name, int32 *prop);
127 void RegisterConstInt32(const std::string &name, const int32 *prop);
Gaurav Shah1b7a6162011-11-09 11:41:01 -0800128 void RegisterWriteOnlyInt32(const std::string &name, int32 *prop);
mukesh agrawal4d260da2012-01-30 11:53:52 -0800129 void RegisterUint32(const std::string &name, uint32 *prop);
Chris Masoneb925cc82011-06-22 15:39:57 -0700130 void RegisterString(const std::string &name, std::string *prop);
131 void RegisterConstString(const std::string &name, const std::string *prop);
Gaurav Shah1b7a6162011-11-09 11:41:01 -0800132 void RegisterWriteOnlyString(const std::string &name, std::string *prop);
Chris Masone43b48a12011-07-01 13:37:07 -0700133 void RegisterStringmap(const std::string &name, Stringmap *prop);
134 void RegisterConstStringmap(const std::string &name, const Stringmap *prop);
Gaurav Shah1b7a6162011-11-09 11:41:01 -0800135 void RegisterWriteOnlyStringmap(const std::string &name, Stringmap *prop);
Darin Petkovc0865312011-09-16 15:31:20 -0700136 void RegisterStringmaps(const std::string &name, Stringmaps *prop);
137 void RegisterConstStringmaps(const std::string &name, const Stringmaps *prop);
Gaurav Shah1b7a6162011-11-09 11:41:01 -0800138 void RegisterWriteOnlyStringmaps(const std::string &name, Stringmaps *prop);
Chris Masone43b48a12011-07-01 13:37:07 -0700139 void RegisterStrings(const std::string &name, Strings *prop);
Chris Masone889666b2011-07-03 12:58:50 -0700140 void RegisterConstStrings(const std::string &name, const Strings *prop);
Gaurav Shah1b7a6162011-11-09 11:41:01 -0800141 void RegisterWriteOnlyStrings(const std::string &name, Strings *prop);
Chris Masone889666b2011-07-03 12:58:50 -0700142 void RegisterUint8(const std::string &name, uint8 *prop);
Chris Masoneb925cc82011-06-22 15:39:57 -0700143 void RegisterConstUint8(const std::string &name, const uint8 *prop);
Gaurav Shah1b7a6162011-11-09 11:41:01 -0800144 void RegisterWriteOnlyUint8(const std::string &name, uint8 *prop);
Chris Masoneb925cc82011-06-22 15:39:57 -0700145 void RegisterUint16(const std::string &name, uint16 *prop);
146 void RegisterConstUint16(const std::string &name, const uint16 *prop);
Gaurav Shah1b7a6162011-11-09 11:41:01 -0800147 void RegisterWriteOnlyUint16(const std::string &name, uint16 *prop);
Chris Masoneb925cc82011-06-22 15:39:57 -0700148
Chris Masone27c4aa52011-07-02 13:10:14 -0700149 void RegisterDerivedBool(const std::string &name,
150 const BoolAccessor &accessor);
mukesh agrawal4d0401c2012-01-06 16:05:31 -0800151 void RegisterDerivedInt32(const std::string &name,
152 const Int32Accessor &accessor);
Darin Petkov63138a92012-02-06 14:09:15 +0100153 void RegisterDerivedKeyValueStore(const std::string &name,
154 const KeyValueStoreAccessor &accessor);
mukesh agrawal2366eed2012-03-20 18:21:50 -0700155 void RegisterDerivedRpcIdentifiers(const std::string &name,
156 const RpcIdentifiersAccessor &accessor);
Chris Masone27c4aa52011-07-02 13:10:14 -0700157 void RegisterDerivedString(const std::string &name,
158 const StringAccessor &accessor);
Chris Masone889666b2011-07-03 12:58:50 -0700159 void RegisterDerivedStringmaps(const std::string &name,
160 const StringmapsAccessor &accessor);
Chris Masone27c4aa52011-07-02 13:10:14 -0700161 void RegisterDerivedStrings(const std::string &name,
162 const StringsAccessor &accessor);
Paul Stewartbe5f5b32011-12-07 17:11:11 -0800163 void RegisterDerivedUint16(const std::string &name,
164 const Uint16Accessor &accessor);
Chris Masone27c4aa52011-07-02 13:10:14 -0700165
166 private:
mukesh agrawalffa3d042011-10-06 15:26:10 -0700167 template <class V>
168 bool SetProperty(
169 const std::string &name,
170 const V &value,
171 Error *error,
172 std::map< std::string, std::tr1::shared_ptr< AccessorInterface<V> > > &,
173 const std::string &value_type_english);
174
Chris Masoneb925cc82011-06-22 15:39:57 -0700175 // These are std::maps instead of something cooler because the common
176 // operation is iterating through them and returning all properties.
177 std::map<std::string, BoolAccessor> bool_properties_;
178 std::map<std::string, Int16Accessor> int16_properties_;
179 std::map<std::string, Int32Accessor> int32_properties_;
Darin Petkov63138a92012-02-06 14:09:15 +0100180 std::map<std::string, KeyValueStoreAccessor> key_value_store_properties_;
mukesh agrawal2366eed2012-03-20 18:21:50 -0700181 std::map<std::string, RpcIdentifiersAccessor> rpc_identifiers_properties_;
Chris Masoneb925cc82011-06-22 15:39:57 -0700182 std::map<std::string, StringAccessor> string_properties_;
183 std::map<std::string, StringmapAccessor> stringmap_properties_;
Chris Masone889666b2011-07-03 12:58:50 -0700184 std::map<std::string, StringmapsAccessor> stringmaps_properties_;
Chris Masoneb925cc82011-06-22 15:39:57 -0700185 std::map<std::string, StringsAccessor> strings_properties_;
186 std::map<std::string, Uint8Accessor> uint8_properties_;
187 std::map<std::string, Uint16Accessor> uint16_properties_;
188 std::map<std::string, Uint32Accessor> uint32_properties_;
189
Chris Masoneb925cc82011-06-22 15:39:57 -0700190 DISALLOW_COPY_AND_ASSIGN(PropertyStore);
191};
192
193} // namespace shill
194
195#endif // SHILL_PROPERTY_STORE_