//
// 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.
//
#ifndef SHILL_KEY_VALUE_STORE_H_
#define SHILL_KEY_VALUE_STORE_H_
#include <map>
#include <string>
#include <vector>
#include <brillo/variant_dictionary.h>
namespace shill {
class KeyValueStore {
// A simple store for key-value pairs, which supports (a limited set of)
// heterogenous value types.
//
// Compare to PropertyStore, which enables a class to (selectively)
// expose its instance members as properties accessible via
// RPC. (RPC support for ProperyStore is implemented in a
// protocol-specific adaptor. e.g. dbus_adpator.)
//
// Implemented separately from PropertyStore, to avoid complicating
// the PropertyStore interface. In particular, objects implementing the
// PropertyStore interface always provide the storage themselves. In
// contrast, users of KeyValueStore expect KeyValueStore to provide
// storage.
public:
KeyValueStore();
// Required for equality comparison when KeyValueStore is wrapped inside a
// brillo::Any object.
bool operator==(const KeyValueStore& rhs) const;
bool operator!=(const KeyValueStore& rhs) const;
void Clear();
void CopyFrom(const KeyValueStore& b);
bool IsEmpty();
bool ContainsBool(const std::string& name) const;
bool ContainsByteArrays(const std::string& name) const;
bool ContainsInt(const std::string& name) const;
bool ContainsInt16(const std::string& name) const;
bool ContainsKeyValueStore(const std::string& name) const;
bool ContainsRpcIdentifier(const std::string& name) const;
bool ContainsRpcIdentifiers(const std::string& name) const;
bool ContainsString(const std::string& name) const;
bool ContainsStringmap(const std::string& name) const;
bool ContainsStrings(const std::string& name) const;
bool ContainsUint(const std::string& name) const;
bool ContainsUint16(const std::string& name) const;
bool ContainsUint8(const std::string& name) const;
bool ContainsUint8s(const std::string& name) const;
bool ContainsUint32s(const std::string& name) const;
bool Contains(const std::string& name) const;
bool GetBool(const std::string& name) const;
const std::vector<std::vector<uint8_t>>& GetByteArrays(
const std::string& name) const;
int32_t GetInt(const std::string& name) const;
int16_t GetInt16(const std::string& name) const;
const KeyValueStore& GetKeyValueStore(const std::string& name) const;
const std::string& GetRpcIdentifier(const std::string& name) const;
std::vector<std::string> GetRpcIdentifiers(const std::string& name) const;
const std::string& GetString(const std::string& name) const;
const std::map<std::string, std::string>& GetStringmap(
const std::string& name) const;
const std::vector<std::string>& GetStrings(const std::string& name) const;
uint32_t GetUint(const std::string& name) const;
uint16_t GetUint16(const std::string& name) const;
uint8_t GetUint8(const std::string& name) const;
const std::vector<uint8_t>& GetUint8s(const std::string& name) const;
const std::vector<uint32_t>& GetUint32s(const std::string& name) const;
const brillo::Any& Get(const std::string& name) const;
// TODO(zqiu): remove type specific set functions and add a generic set
// function instead. This way, we don't need to add new functions every
// time we need to support a new type.
void SetBool(const std::string& name, bool value);
void SetByteArrays(const std::string& name,
const std::vector<std::vector<uint8_t>>& value);
void SetInt(const std::string& name, int32_t value);
void SetInt16(const std::string& name, int16_t value);
void SetKeyValueStore(const std::string& name, const KeyValueStore& value);
void SetRpcIdentifier(const std::string& name, const std::string& value);
void SetRpcIdentifiers(const std::string& name,
const std::vector<std::string>& value);
void SetString(const std::string& name, const std::string& value);
void SetStringmap(const std::string& name,
const std::map<std::string, std::string>& value);
void SetStrings(const std::string& name,
const std::vector<std::string>& value);
void SetUint(const std::string& name, uint32_t value);
void SetUint16(const std::string& name, uint16_t value);
void SetUint8(const std::string& name, uint8_t value);
void SetUint8s(const std::string& name, const std::vector<uint8_t>& value);
void SetUint32s(const std::string& name, const std::vector<uint32_t>& value);
void Set(const std::string& name, const brillo::Any& value);
// TODO(zqiu): remove type specific remove functions and add a generic remove
// function instead.
void RemoveString(const std::string& name);
void RemoveStringmap(const std::string& name);
void RemoveStrings(const std::string& name);
void RemoveInt(const std::string& name);
void RemoveKeyValueStore(const std::string& name);
void RemoveInt16(const std::string& name);
void RemoveRpcIdentifier(const std::string& name);
void RemoveByteArrays(const std::string& name);
void RemoveUint16(const std::string& name);
void RemoveUint8(const std::string& name);
void RemoveUint8s(const std::string& name);
void RemoveUint32s(const std::string& name);
void Remove(const std::string& name);
// If |name| is in this store returns its value, otherwise returns
// |default_value|.
bool LookupBool(const std::string& name, bool default_value) const;
int LookupInt(const std::string& name, int default_value) const;
std::string LookupString(const std::string& name,
const std::string& default_value) const;
const brillo::VariantDictionary& properties() const {
return properties_;
}
// Conversion function between KeyValueStore and brillo::VariantDictionary.
// Since we already use brillo::VariantDictionary for storing key value
// pairs, all conversions will be trivial except nested KeyValueStore and
// nested brillo::VariantDictionary.
static void ConvertToVariantDictionary(const KeyValueStore& in_store,
brillo::VariantDictionary* out_dict);
static void ConvertFromVariantDictionary(
const brillo::VariantDictionary& in_dict, KeyValueStore* out_store);
static void ConvertPathsToRpcIdentifiers(
const std::vector<dbus::ObjectPath>& paths,
std::vector<std::string>* rpc_identifiers);
private:
brillo::VariantDictionary properties_;
};
} // namespace shill
#endif // SHILL_KEY_VALUE_STORE_H_