// // Copyright (C) 2012 The Android Open Source Project // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // #include "shill/property_store.h" #include <map> #include <string> #include <vector> #include <base/stl_util.h> #include <dbus/object_path.h> #include "shill/error.h" #include "shill/logging.h" #include "shill/property_accessor.h" using std::map; using std::string; using std::vector; namespace shill { namespace Logging { static auto kModuleLogScope = ScopeLogger::kProperty; static string ObjectID(const PropertyStore* p) { return "(property_store)"; } } PropertyStore::PropertyStore() {} PropertyStore::PropertyStore(PropertyChangeCallback on_property_changed) : property_changed_callback_(on_property_changed) {} PropertyStore::~PropertyStore() {} bool PropertyStore::Contains(const string& prop) const { return (ContainsKey(bool_properties_, prop) || ContainsKey(int16_properties_, prop) || ContainsKey(int32_properties_, prop) || ContainsKey(key_value_store_properties_, prop) || ContainsKey(string_properties_, prop) || ContainsKey(stringmap_properties_, prop) || ContainsKey(stringmaps_properties_, prop) || ContainsKey(strings_properties_, prop) || ContainsKey(uint8_properties_, prop) || ContainsKey(bytearray_properties_, prop) || ContainsKey(uint16_properties_, prop) || ContainsKey(uint16s_properties_, prop) || ContainsKey(uint32_properties_, prop) || ContainsKey(uint64_properties_, prop) || ContainsKey(rpc_identifier_properties_, prop) || ContainsKey(rpc_identifiers_properties_, prop)); } bool PropertyStore::SetAnyProperty(const string& name, const brillo::Any& value, Error* error) { bool ret = false; if (value.IsTypeCompatible<bool>()) { ret = SetBoolProperty(name, value.Get<bool>(), error); } else if (value.IsTypeCompatible<uint8_t>()) { ret = SetUint8Property(name, value.Get<uint8_t>(), error); } else if (value.IsTypeCompatible<int16_t>()) { ret = SetInt16Property(name, value.Get<int16_t>(), error); } else if (value.IsTypeCompatible<int32_t>()) { ret = SetInt32Property(name, value.Get<int32_t>(), error); } else if (value.IsTypeCompatible<dbus::ObjectPath>()) { ret = SetStringProperty(name, value.Get<dbus::ObjectPath>().value(), error); } else if (value.IsTypeCompatible<string>()) { ret = SetStringProperty(name, value.Get<string>(), error); } else if (value.IsTypeCompatible<Stringmap>()) { ret = SetStringmapProperty(name, value.Get<Stringmap>(), error); } else if (value.IsTypeCompatible<Stringmaps>()) { SLOG(nullptr, 1) << " can't yet handle setting type " << value.GetUndecoratedTypeName(); error->Populate(Error::kInternalError); } else if (value.IsTypeCompatible<Strings>()) { ret = SetStringsProperty(name, value.Get<Strings>(), error); } else if (value.IsTypeCompatible<ByteArray>()) { ret = SetByteArrayProperty(name, value.Get<ByteArray>(), error); } else if (value.IsTypeCompatible<uint16_t>()) { ret = SetUint16Property(name, value.Get<uint16_t>(), error); } else if (value.IsTypeCompatible<Uint16s>()) { ret = SetUint16sProperty(name, value.Get<Uint16s>(), error); } else if (value.IsTypeCompatible<uint32_t>()) { ret = SetUint32Property(name, value.Get<uint32_t>(), error); } else if (value.IsTypeCompatible<uint64_t>()) { ret = SetUint64Property(name, value.Get<uint64_t>(), error); } else if (value.IsTypeCompatible<brillo::VariantDictionary>()) { KeyValueStore store; KeyValueStore::ConvertFromVariantDictionary( value.Get<brillo::VariantDictionary>(), &store); ret = SetKeyValueStoreProperty(name, store, error); } else { NOTREACHED() << " unknown type: " << value.GetUndecoratedTypeName(); error->Populate(Error::kInternalError); } return ret; } bool PropertyStore::SetProperties(const brillo::VariantDictionary& in, Error* error) { for (const auto& kv : in) { if (!SetAnyProperty(kv.first, kv.second, error)) { return false; } } return true; } bool PropertyStore::GetProperties(brillo::VariantDictionary* out, Error* error) const { { ReadablePropertyConstIterator<bool> it = GetBoolPropertiesIter(); for ( ; !it.AtEnd(); it.Advance()) { out->insert(std::make_pair(it.Key(), brillo::Any(it.value()))); } } { ReadablePropertyConstIterator<int16_t> it = GetInt16PropertiesIter(); for ( ; !it.AtEnd(); it.Advance()) { out->insert(std::make_pair(it.Key(), brillo::Any(it.value()))); } } { ReadablePropertyConstIterator<int32_t> it = GetInt32PropertiesIter(); for ( ; !it.AtEnd(); it.Advance()) { out->insert(std::make_pair(it.Key(), brillo::Any(it.value()))); } } { ReadablePropertyConstIterator<RpcIdentifier> it = GetRpcIdentifierPropertiesIter(); for ( ; !it.AtEnd(); it.Advance()) { out->insert( std::make_pair(it.Key(), brillo::Any(dbus::ObjectPath(it.value())))); } } { ReadablePropertyConstIterator<RpcIdentifiers> it = GetRpcIdentifiersPropertiesIter(); for ( ; !it.AtEnd(); it.Advance()) { vector<dbus::ObjectPath> rpc_identifiers_as_paths; for (const auto& path : it.value()) { rpc_identifiers_as_paths.push_back(dbus::ObjectPath(path)); } out->insert( std::make_pair(it.Key(), brillo::Any(rpc_identifiers_as_paths))); } } { ReadablePropertyConstIterator<string> it = GetStringPropertiesIter(); for ( ; !it.AtEnd(); it.Advance()) { out->insert(std::make_pair(it.Key(), brillo::Any(it.value()))); } } { ReadablePropertyConstIterator<Stringmap> it = GetStringmapPropertiesIter(); for ( ; !it.AtEnd(); it.Advance()) { out->insert(std::make_pair(it.Key(), brillo::Any(it.value()))); } } { ReadablePropertyConstIterator<Stringmaps> it = GetStringmapsPropertiesIter(); for ( ; !it.AtEnd(); it.Advance()) { out->insert(std::make_pair(it.Key(), brillo::Any(it.value()))); } } { ReadablePropertyConstIterator<Strings> it = GetStringsPropertiesIter(); for ( ; !it.AtEnd(); it.Advance()) { out->insert(std::make_pair(it.Key(), brillo::Any(it.value()))); } } { ReadablePropertyConstIterator<uint8_t> it = GetUint8PropertiesIter(); for ( ; !it.AtEnd(); it.Advance()) { out->insert(std::make_pair(it.Key(), brillo::Any(it.value()))); } } { ReadablePropertyConstIterator<ByteArray> it = GetByteArrayPropertiesIter(); for ( ; !it.AtEnd(); it.Advance()) { out->insert(std::make_pair(it.Key(), brillo::Any(it.value()))); } } { ReadablePropertyConstIterator<uint16_t> it = GetUint16PropertiesIter(); for ( ; !it.AtEnd(); it.Advance()) { out->insert(std::make_pair(it.Key(), brillo::Any(it.value()))); } } { ReadablePropertyConstIterator<Uint16s> it = GetUint16sPropertiesIter(); for ( ; !it.AtEnd(); it.Advance()) { out->insert(std::make_pair(it.Key(), brillo::Any(it.value()))); } } { ReadablePropertyConstIterator<uint32_t> it = GetUint32PropertiesIter(); for ( ; !it.AtEnd(); it.Advance()) { out->insert(std::make_pair(it.Key(), brillo::Any(it.value()))); } } { ReadablePropertyConstIterator<uint64_t> it = GetUint64PropertiesIter(); for ( ; !it.AtEnd(); it.Advance()) { out->insert(std::make_pair(it.Key(), brillo::Any(it.value()))); } } { ReadablePropertyConstIterator<KeyValueStore> it = GetKeyValueStorePropertiesIter(); for ( ; !it.AtEnd(); it.Advance()) { brillo::VariantDictionary dict; KeyValueStore::ConvertToVariantDictionary(it.value(), &dict); out->insert(std::make_pair(it.Key(), dict)); } } return true; } bool PropertyStore::GetBoolProperty(const string& name, bool* value, Error* error) const { return GetProperty(name, value, error, bool_properties_, "a bool"); } bool PropertyStore::GetInt16Property(const string& name, int16_t* value, Error* error) const { return GetProperty(name, value, error, int16_properties_, "an int16_t"); } bool PropertyStore::GetInt32Property(const string& name, int32_t* value, Error* error) const { return GetProperty(name, value, error, int32_properties_, "an int32_t"); } bool PropertyStore::GetKeyValueStoreProperty(const string& name, KeyValueStore* value, Error* error) const { return GetProperty(name, value, error, key_value_store_properties_, "a key value store"); } bool PropertyStore::GetRpcIdentifierProperty(const string& name, RpcIdentifier* value, Error* error) const { return GetProperty(name, value, error, rpc_identifier_properties_, "an rpc_identifier"); } bool PropertyStore::GetStringProperty(const string& name, string* value, Error* error) const { return GetProperty(name, value, error, string_properties_, "a string"); } bool PropertyStore::GetStringmapProperty(const string& name, Stringmap* values, Error* error) const { return GetProperty(name, values, error, stringmap_properties_, "a string map"); } bool PropertyStore::GetStringmapsProperty(const string& name, Stringmaps* values, Error* error) const { return GetProperty(name, values, error, stringmaps_properties_, "a string map list"); } bool PropertyStore::GetStringsProperty(const string& name, Strings* values, Error* error) const { return GetProperty(name, values, error, strings_properties_, "a string list"); } bool PropertyStore::GetUint8Property(const string& name, uint8_t* value, Error* error) const { return GetProperty(name, value, error, uint8_properties_, "a uint8_t"); } bool PropertyStore::GetByteArrayProperty(const string& name, ByteArray* value, Error *error) const { return GetProperty(name, value, error, bytearray_properties_, "a byte array"); } bool PropertyStore::GetUint16Property(const string& name, uint16_t* value, Error* error) const { return GetProperty(name, value, error, uint16_properties_, "a uint16_t"); } bool PropertyStore::GetUint16sProperty(const string& name, Uint16s* value, Error* error) const { return GetProperty(name, value, error, uint16s_properties_, "a uint16_t list"); } bool PropertyStore::GetUint32Property(const string& name, uint32_t* value, Error* error) const { return GetProperty(name, value, error, uint32_properties_, "a uint32_t"); } bool PropertyStore::GetUint64Property(const string& name, uint64_t* value, Error* error) const { return GetProperty(name, value, error, uint64_properties_, "a uint64_t"); } bool PropertyStore::SetBoolProperty(const string& name, bool value, Error* error) { return SetProperty(name, value, error, &bool_properties_, "a bool"); } bool PropertyStore::SetInt16Property(const string& name, int16_t value, Error* error) { return SetProperty(name, value, error, &int16_properties_, "an int16_t"); } bool PropertyStore::SetInt32Property(const string& name, int32_t value, Error* error) { return SetProperty(name, value, error, &int32_properties_, "an int32_t."); } bool PropertyStore::SetKeyValueStoreProperty(const string& name, const KeyValueStore& value, Error* error) { return SetProperty(name, value, error, &key_value_store_properties_, "a key value store"); } bool PropertyStore::SetStringProperty(const string& name, const string& value, Error* error) { return SetProperty(name, value, error, &string_properties_, "a string"); } bool PropertyStore::SetStringmapProperty(const string& name, const map<string, string>& values, Error* error) { return SetProperty(name, values, error, &stringmap_properties_, "a string map"); } bool PropertyStore::SetStringmapsProperty( const string& name, const vector<map<string, string>>& values, Error* error) { return SetProperty(name, values, error, &stringmaps_properties_, "a stringmaps"); } bool PropertyStore::SetStringsProperty(const string& name, const vector<string>& values, Error* error) { return SetProperty(name, values, error, &strings_properties_, "a string list"); } bool PropertyStore::SetUint8Property(const string& name, uint8_t value, Error* error) { return SetProperty(name, value, error, &uint8_properties_, "a uint8_t"); } bool PropertyStore::SetByteArrayProperty(const string& name, const ByteArray& value, Error *error) { return SetProperty(name, value, error, &bytearray_properties_, "a byte array"); } bool PropertyStore::SetUint16Property(const string& name, uint16_t value, Error* error) { return SetProperty(name, value, error, &uint16_properties_, "a uint16_t"); } bool PropertyStore::SetUint16sProperty(const string& name, const vector<uint16_t>& value, Error* error) { return SetProperty(name, value, error, &uint16s_properties_, "a uint16_t list"); } bool PropertyStore::SetUint32Property(const string& name, uint32_t value, Error* error) { return SetProperty(name, value, error, &uint32_properties_, "a uint32_t"); } bool PropertyStore::SetUint64Property(const string& name, uint64_t value, Error* error) { return SetProperty(name, value, error, &uint64_properties_, "a uint64_t"); } bool PropertyStore::SetRpcIdentifierProperty(const string& name, const RpcIdentifier& value, Error* error) { return SetProperty(name, value, error, &rpc_identifier_properties_, "an rpc_identifier"); } bool PropertyStore::ClearProperty(const string& name, Error* error) { SLOG(this, 2) << "Clearing " << name << "."; if (ContainsKey(bool_properties_, name)) { bool_properties_[name]->Clear(error); } else if (ContainsKey(int16_properties_, name)) { int16_properties_[name]->Clear(error); } else if (ContainsKey(int32_properties_, name)) { int32_properties_[name]->Clear(error); } else if (ContainsKey(key_value_store_properties_, name)) { key_value_store_properties_[name]->Clear(error); } else if (ContainsKey(string_properties_, name)) { string_properties_[name]->Clear(error); } else if (ContainsKey(stringmap_properties_, name)) { stringmap_properties_[name]->Clear(error); } else if (ContainsKey(stringmaps_properties_, name)) { stringmaps_properties_[name]->Clear(error); } else if (ContainsKey(strings_properties_, name)) { strings_properties_[name]->Clear(error); } else if (ContainsKey(uint8_properties_, name)) { uint8_properties_[name]->Clear(error); } else if (ContainsKey(uint16_properties_, name)) { uint16_properties_[name]->Clear(error); } else if (ContainsKey(uint16s_properties_, name)) { uint16s_properties_[name]->Clear(error); } else if (ContainsKey(uint32_properties_, name)) { uint32_properties_[name]->Clear(error); } else if (ContainsKey(uint64_properties_, name)) { uint64_properties_[name]->Clear(error); } else if (ContainsKey(rpc_identifier_properties_, name)) { rpc_identifier_properties_[name]->Clear(error); } else if (ContainsKey(rpc_identifiers_properties_, name)) { rpc_identifiers_properties_[name]->Clear(error); } else { error->Populate( Error::kInvalidProperty, "Property " + name + " does not exist."); } if (error->IsSuccess()) { if (!property_changed_callback_.is_null()) { property_changed_callback_.Run(name); } } return error->IsSuccess(); } ReadablePropertyConstIterator<bool> PropertyStore::GetBoolPropertiesIter() const { return ReadablePropertyConstIterator<bool>(bool_properties_); } ReadablePropertyConstIterator<int16_t> PropertyStore::GetInt16PropertiesIter() const { return ReadablePropertyConstIterator<int16_t>(int16_properties_); } ReadablePropertyConstIterator<int32_t> PropertyStore::GetInt32PropertiesIter() const { return ReadablePropertyConstIterator<int32_t>(int32_properties_); } ReadablePropertyConstIterator<KeyValueStore> PropertyStore::GetKeyValueStorePropertiesIter() const { return ReadablePropertyConstIterator<KeyValueStore>(key_value_store_properties_); } ReadablePropertyConstIterator<RpcIdentifier> PropertyStore::GetRpcIdentifierPropertiesIter() const { return ReadablePropertyConstIterator<RpcIdentifier>( rpc_identifier_properties_); } ReadablePropertyConstIterator<RpcIdentifiers> PropertyStore::GetRpcIdentifiersPropertiesIter() const { return ReadablePropertyConstIterator<RpcIdentifiers>( rpc_identifiers_properties_); } ReadablePropertyConstIterator<string> PropertyStore::GetStringPropertiesIter() const { return ReadablePropertyConstIterator<string>(string_properties_); } ReadablePropertyConstIterator<Stringmap> PropertyStore::GetStringmapPropertiesIter() const { return ReadablePropertyConstIterator<Stringmap>(stringmap_properties_); } ReadablePropertyConstIterator<Stringmaps> PropertyStore::GetStringmapsPropertiesIter() const { return ReadablePropertyConstIterator<Stringmaps>(stringmaps_properties_); } ReadablePropertyConstIterator<Strings> PropertyStore::GetStringsPropertiesIter() const { return ReadablePropertyConstIterator<Strings>(strings_properties_); } ReadablePropertyConstIterator<uint8_t> PropertyStore::GetUint8PropertiesIter() const { return ReadablePropertyConstIterator<uint8_t>(uint8_properties_); } ReadablePropertyConstIterator<ByteArray> PropertyStore::GetByteArrayPropertiesIter() const { return ReadablePropertyConstIterator<ByteArray>(bytearray_properties_); } ReadablePropertyConstIterator<uint16_t> PropertyStore::GetUint16PropertiesIter() const { return ReadablePropertyConstIterator<uint16_t>(uint16_properties_); } ReadablePropertyConstIterator<Uint16s> PropertyStore::GetUint16sPropertiesIter() const { return ReadablePropertyConstIterator<Uint16s>(uint16s_properties_); } ReadablePropertyConstIterator<uint32_t> PropertyStore::GetUint32PropertiesIter() const { return ReadablePropertyConstIterator<uint32_t>(uint32_properties_); } ReadablePropertyConstIterator<uint64_t> PropertyStore::GetUint64PropertiesIter() const { return ReadablePropertyConstIterator<uint64_t>(uint64_properties_); } void PropertyStore::RegisterBool(const string& name, bool* prop) { DCHECK(!Contains(name) || ContainsKey(bool_properties_, name)) << "(Already registered " << name << ")"; bool_properties_[name] = BoolAccessor(new PropertyAccessor<bool>(prop)); } void PropertyStore::RegisterConstBool(const string& name, const bool* prop) { DCHECK(!Contains(name) || ContainsKey(bool_properties_, name)) << "(Already registered " << name << ")"; bool_properties_[name] = BoolAccessor(new ConstPropertyAccessor<bool>(prop)); } void PropertyStore::RegisterWriteOnlyBool(const string& name, bool* prop) { DCHECK(!Contains(name) || ContainsKey(bool_properties_, name)) << "(Already registered " << name << ")"; bool_properties_[name] = BoolAccessor( new WriteOnlyPropertyAccessor<bool>(prop)); } void PropertyStore::RegisterInt16(const string& name, int16_t* prop) { DCHECK(!Contains(name) || ContainsKey(int16_properties_, name)) << "(Already registered " << name << ")"; int16_properties_[name] = Int16Accessor(new PropertyAccessor<int16_t>(prop)); } void PropertyStore::RegisterConstInt16(const string& name, const int16_t* prop) { DCHECK(!Contains(name) || ContainsKey(int16_properties_, name)) << "(Already registered " << name << ")"; int16_properties_[name] = Int16Accessor(new ConstPropertyAccessor<int16_t>(prop)); } void PropertyStore::RegisterWriteOnlyInt16(const string& name, int16_t* prop) { DCHECK(!Contains(name) || ContainsKey(int16_properties_, name)) << "(Already registered " << name << ")"; int16_properties_[name] = Int16Accessor(new WriteOnlyPropertyAccessor<int16_t>(prop)); } void PropertyStore::RegisterInt32(const string& name, int32_t* prop) { DCHECK(!Contains(name) || ContainsKey(int32_properties_, name)) << "(Already registered " << name << ")"; int32_properties_[name] = Int32Accessor(new PropertyAccessor<int32_t>(prop)); } void PropertyStore::RegisterConstInt32(const string& name, const int32_t* prop) { DCHECK(!Contains(name) || ContainsKey(int32_properties_, name)) << "(Already registered " << name << ")"; int32_properties_[name] = Int32Accessor(new ConstPropertyAccessor<int32_t>(prop)); } void PropertyStore::RegisterWriteOnlyInt32(const string& name, int32_t* prop) { DCHECK(!Contains(name) || ContainsKey(int32_properties_, name)) << "(Already registered " << name << ")"; int32_properties_[name] = Int32Accessor(new WriteOnlyPropertyAccessor<int32_t>(prop)); } void PropertyStore::RegisterString(const string& name, string* prop) { DCHECK(!Contains(name) || ContainsKey(string_properties_, name)) << "(Already registered " << name << ")"; string_properties_[name] = StringAccessor(new PropertyAccessor<string>(prop)); } void PropertyStore::RegisterConstString(const string& name, const string* prop) { DCHECK(!Contains(name) || ContainsKey(string_properties_, name)) << "(Already registered " << name << ")"; string_properties_[name] = StringAccessor(new ConstPropertyAccessor<string>(prop)); } void PropertyStore::RegisterWriteOnlyString(const string& name, string* prop) { DCHECK(!Contains(name) || ContainsKey(string_properties_, name)) << "(Already registered " << name << ")"; string_properties_[name] = StringAccessor(new WriteOnlyPropertyAccessor<string>(prop)); } void PropertyStore::RegisterStringmap(const string& name, Stringmap* prop) { DCHECK(!Contains(name) || ContainsKey(stringmap_properties_, name)) << "(Already registered " << name << ")"; stringmap_properties_[name] = StringmapAccessor(new PropertyAccessor<Stringmap>(prop)); } void PropertyStore::RegisterConstStringmap(const string& name, const Stringmap* prop) { DCHECK(!Contains(name) || ContainsKey(stringmap_properties_, name)) << "(Already registered " << name << ")"; stringmap_properties_[name] = StringmapAccessor(new ConstPropertyAccessor<Stringmap>(prop)); } void PropertyStore::RegisterWriteOnlyStringmap(const string& name, Stringmap* prop) { DCHECK(!Contains(name) || ContainsKey(stringmap_properties_, name)) << "(Already registered " << name << ")"; stringmap_properties_[name] = StringmapAccessor(new WriteOnlyPropertyAccessor<Stringmap>(prop)); } void PropertyStore::RegisterStringmaps(const string& name, Stringmaps* prop) { DCHECK(!Contains(name) || ContainsKey(stringmaps_properties_, name)) << "(Already registered " << name << ")"; stringmaps_properties_[name] = StringmapsAccessor(new PropertyAccessor<Stringmaps>(prop)); } void PropertyStore::RegisterConstStringmaps(const string& name, const Stringmaps* prop) { DCHECK(!Contains(name) || ContainsKey(stringmaps_properties_, name)) << "(Already registered " << name << ")"; stringmaps_properties_[name] = StringmapsAccessor(new ConstPropertyAccessor<Stringmaps>(prop)); } void PropertyStore::RegisterWriteOnlyStringmaps(const string& name, Stringmaps* prop) { DCHECK(!Contains(name) || ContainsKey(stringmaps_properties_, name)) << "(Already registered " << name << ")"; stringmaps_properties_[name] = StringmapsAccessor(new WriteOnlyPropertyAccessor<Stringmaps>(prop)); } void PropertyStore::RegisterStrings(const string& name, Strings* prop) { DCHECK(!Contains(name) || ContainsKey(strings_properties_, name)) << "(Already registered " << name << ")"; strings_properties_[name] = StringsAccessor(new PropertyAccessor<Strings>(prop)); } void PropertyStore::RegisterConstStrings(const string& name, const Strings* prop) { DCHECK(!Contains(name) || ContainsKey(strings_properties_, name)) << "(Already registered " << name << ")"; strings_properties_[name] = StringsAccessor(new ConstPropertyAccessor<Strings>(prop)); } void PropertyStore::RegisterWriteOnlyStrings(const string& name, Strings* prop) { DCHECK(!Contains(name) || ContainsKey(strings_properties_, name)) << "(Already registered " << name << ")"; strings_properties_[name] = StringsAccessor(new WriteOnlyPropertyAccessor<Strings>(prop)); } void PropertyStore::RegisterUint8(const string& name, uint8_t* prop) { DCHECK(!Contains(name) || ContainsKey(uint8_properties_, name)) << "(Already registered " << name << ")"; uint8_properties_[name] = Uint8Accessor(new PropertyAccessor<uint8_t>(prop)); } void PropertyStore::RegisterConstUint8(const string& name, const uint8_t* prop) { DCHECK(!Contains(name) || ContainsKey(uint8_properties_, name)) << "(Already registered " << name << ")"; uint8_properties_[name] = Uint8Accessor(new ConstPropertyAccessor<uint8_t>(prop)); } void PropertyStore::RegisterWriteOnlyUint8(const string& name, uint8_t* prop) { DCHECK(!Contains(name) || ContainsKey(uint8_properties_, name)) << "(Already registered " << name << ")"; uint8_properties_[name] = Uint8Accessor(new WriteOnlyPropertyAccessor<uint8_t>(prop)); } void PropertyStore::RegisterByteArray(const string& name, ByteArray* prop) { DCHECK(!Contains(name) || ContainsKey(bytearray_properties_, name)) << "(Already registered " << name << ")"; bytearray_properties_[name] = ByteArrayAccessor(new PropertyAccessor<ByteArray>(prop)); } void PropertyStore::RegisterConstByteArray(const string& name, const ByteArray* prop) { DCHECK(!Contains(name) || ContainsKey(bytearray_properties_, name)) << "(Already registered " << name << ")"; bytearray_properties_[name] = ByteArrayAccessor(new ConstPropertyAccessor<ByteArray>(prop)); } void PropertyStore::RegisterWriteOnlyByteArray(const string& name, ByteArray* prop) { DCHECK(!Contains(name) || ContainsKey(bytearray_properties_, name)) << "(Already registered " << name << ")"; bytearray_properties_[name] = ByteArrayAccessor(new WriteOnlyPropertyAccessor<ByteArray>(prop)); } void PropertyStore::RegisterUint16(const string& name, uint16_t* prop) { DCHECK(!Contains(name) || ContainsKey(uint16_properties_, name)) << "(Already registered " << name << ")"; uint16_properties_[name] = Uint16Accessor(new PropertyAccessor<uint16_t>(prop)); } void PropertyStore::RegisterUint16s(const string& name, Uint16s* prop) { DCHECK(!Contains(name) || ContainsKey(uint16s_properties_, name)) << "(Already registered " << name << ")"; uint16s_properties_[name] = Uint16sAccessor(new PropertyAccessor<Uint16s>(prop)); } void PropertyStore::RegisterUint32(const std::string& name, uint32_t* prop) { DCHECK(!Contains(name) || ContainsKey(uint32_properties_, name)) << "(Already registered " << name << ")"; uint32_properties_[name] = Uint32Accessor(new PropertyAccessor<uint32_t>(prop)); } void PropertyStore::RegisterConstUint32(const string& name, const uint32_t* prop) { DCHECK(!Contains(name) || ContainsKey(uint32_properties_, name)) << "(Already registered " << name << ")"; uint32_properties_[name] = Uint32Accessor(new ConstPropertyAccessor<uint32_t>(prop)); } void PropertyStore::RegisterConstUint16(const string& name, const uint16_t* prop) { DCHECK(!Contains(name) || ContainsKey(uint16_properties_, name)) << "(Already registered " << name << ")"; uint16_properties_[name] = Uint16Accessor(new ConstPropertyAccessor<uint16_t>(prop)); } void PropertyStore::RegisterConstUint16s(const string& name, const Uint16s* prop) { DCHECK(!Contains(name) || ContainsKey(uint16s_properties_, name)) << "(Already registered " << name << ")"; uint16s_properties_[name] = Uint16sAccessor(new ConstPropertyAccessor<Uint16s>(prop)); } void PropertyStore::RegisterWriteOnlyUint16(const string& name, uint16_t* prop) { DCHECK(!Contains(name) || ContainsKey(uint16_properties_, name)) << "(Already registered " << name << ")"; uint16_properties_[name] = Uint16Accessor(new WriteOnlyPropertyAccessor<uint16_t>(prop)); } void PropertyStore::RegisterDerivedBool(const string& name, const BoolAccessor& accessor) { DCHECK(!Contains(name) || ContainsKey(bool_properties_, name)) << "(Already registered " << name << ")"; bool_properties_[name] = accessor; } void PropertyStore::RegisterDerivedInt32(const string& name, const Int32Accessor& accessor) { DCHECK(!Contains(name) || ContainsKey(int32_properties_, name)) << "(Already registered " << name << ")"; int32_properties_[name] = accessor; } void PropertyStore::RegisterDerivedKeyValueStore( const string& name, const KeyValueStoreAccessor& acc) { DCHECK(!Contains(name) || ContainsKey(key_value_store_properties_, name)) << "(Already registered " << name << ")"; key_value_store_properties_[name] = acc; } void PropertyStore::RegisterDerivedRpcIdentifier( const string& name, const RpcIdentifierAccessor& acc) { DCHECK(!Contains(name) || ContainsKey(rpc_identifier_properties_, name)) << "(Already registered " << name << ")"; rpc_identifier_properties_[name] = acc; } void PropertyStore::RegisterDerivedRpcIdentifiers( const string& name, const RpcIdentifiersAccessor& accessor) { DCHECK(!Contains(name) || ContainsKey(rpc_identifiers_properties_, name)) << "(Already registered " << name << ")"; rpc_identifiers_properties_[name] = accessor; } void PropertyStore::RegisterDerivedString(const string& name, const StringAccessor& accessor) { DCHECK(!Contains(name) || ContainsKey(string_properties_, name)) << "(Already registered " << name << ")"; string_properties_[name] = accessor; } void PropertyStore::RegisterDerivedStrings(const string& name, const StringsAccessor& accessor) { DCHECK(!Contains(name) || ContainsKey(strings_properties_, name)) << "(Already registered " << name << ")"; strings_properties_[name] = accessor; } void PropertyStore::RegisterDerivedStringmap(const string& name, const StringmapAccessor& acc) { DCHECK(!Contains(name) || ContainsKey(stringmap_properties_, name)) << "(Already registered " << name << ")"; stringmap_properties_[name] = acc; } void PropertyStore::RegisterDerivedStringmaps(const string& name, const StringmapsAccessor& acc) { DCHECK(!Contains(name) || ContainsKey(stringmaps_properties_, name)) << "(Already registered " << name << ")"; stringmaps_properties_[name] = acc; } void PropertyStore::RegisterDerivedUint16(const string& name, const Uint16Accessor& acc) { DCHECK(!Contains(name) || ContainsKey(uint16_properties_, name)) << "(Already registered " << name << ")"; uint16_properties_[name] = acc; } void PropertyStore::RegisterDerivedUint64(const string& name, const Uint64Accessor& acc) { DCHECK(!Contains(name) || ContainsKey(uint64_properties_, name)) << "(Already registered " << name << ")"; uint64_properties_[name] = acc; } void PropertyStore::RegisterDerivedByteArray(const string& name, const ByteArrayAccessor& acc) { DCHECK(!Contains(name) || ContainsKey(bytearray_properties_, name)) << "(Already registered " << name << ")"; bytearray_properties_[name] = acc; } // private methods template <class V> bool PropertyStore::GetProperty( const string& name, V* value, Error* error, const map<string, std::shared_ptr<AccessorInterface<V>>>& collection, const string& value_type_english) const { SLOG(this, 2) << "Getting " << name << " as " << value_type_english << "."; typename map<string, std::shared_ptr<AccessorInterface<V>>>::const_iterator it = collection.find(name); if (it != collection.end()) { V val = it->second->Get(error); if (error->IsSuccess()) { *value = val; } } else { if (Contains(name)) { error->Populate( Error::kInvalidArguments, "Property " + name + " is not " + value_type_english + "."); } else { error->Populate( Error::kInvalidProperty, "Property " + name + " does not exist."); } } return error->IsSuccess(); } template <class V> bool PropertyStore::SetProperty( const string& name, const V& value, Error* error, map<string, std::shared_ptr<AccessorInterface<V>>>* collection, const string& value_type_english) { bool ret = false; SLOG(this, 2) << "Setting " << name << " as " << value_type_english << "."; if (ContainsKey(*collection, name)) { ret = (*collection)[name]->Set(value, error); if (ret) { if (!property_changed_callback_.is_null()) { property_changed_callback_.Run(name); } } } else { if (Contains(name)) { error->Populate( Error::kInvalidArguments, "Property " + name + " is not " + value_type_english + "."); } else { error->Populate( Error::kInvalidProperty, "Property " + name + " does not exist."); } } return ret; } } // namespace shill