blob: b2d1295fdf821f6d4b6f5d9ac2ce1884254d0373 [file] [log] [blame]
Paul Lawrence61980262015-03-16 15:35:55 -07001#include <string>
2#include <fstream>
3
4// key names for properties we use
5namespace properties {
6 extern const char* key;
7 extern const char* ref;
Paul Lawrence2ecc6422015-04-15 14:11:07 -07008 extern const char* props;
Paul Lawrencebc2eb8c2015-04-28 22:13:04 +00009 extern const char* is_default;
Paul Lawrence61980262015-03-16 15:35:55 -070010}
11
12/**
13 * Class to store data on the unencrypted folder of a device.
14 * Note that the folder must exist before this class is constructed.
15 * All names must be valid single level (no '/') file or directory names
16 * Data is organized hierarchically so we can get a child folder
17 */
18class UnencryptedProperties
19{
20public:
Paul Lawrencebc2eb8c2015-04-28 22:13:04 +000021 // Get path of folder. Must create before using any properties
22 // This is to allow proper setting of SELinux policy
23 static std::string GetPath(const char* device);
24
Paul Lawrence61980262015-03-16 15:35:55 -070025 // Opens properties folder on named device.
Paul Lawrencebc2eb8c2015-04-28 22:13:04 +000026 // If folder does not exist, OK will return false, all
Paul Lawrence61980262015-03-16 15:35:55 -070027 // getters will return default properties and setters will fail.
28 UnencryptedProperties(const char* device);
29
30 // Get named object. Return default if object does not exist or error.
Paul Lawrencebc2eb8c2015-04-28 22:13:04 +000031 template<typename t> t Get(const char* name, t default_value = t()) const;
Paul Lawrence61980262015-03-16 15:35:55 -070032
33 // Set named object. Return true if success, false otherwise
34 template<typename t> bool Set(const char* name, t const& value);
35
36 // Get child properties
Paul Lawrencebc2eb8c2015-04-28 22:13:04 +000037 UnencryptedProperties GetChild(const char* name) const;
Paul Lawrence61980262015-03-16 15:35:55 -070038
39 // Remove named object
40 bool Remove(const char* name);
41
Paul Lawrencebc2eb8c2015-04-28 22:13:04 +000042 // Does folder exist?
43 bool OK() const;
44
Paul Lawrence61980262015-03-16 15:35:55 -070045private:
46 UnencryptedProperties();
Paul Lawrence61980262015-03-16 15:35:55 -070047 std::string folder_;
48};
49
50
51template<typename t> t UnencryptedProperties::Get(const char* name,
Paul Lawrencebc2eb8c2015-04-28 22:13:04 +000052 t default_value) const
Paul Lawrence61980262015-03-16 15:35:55 -070053{
54 if (!OK()) return default_value;
55 t value = default_value;
56 std::ifstream(folder_ + "/" + name) >> value;
57 return value;
58}
59
60template<typename t> bool UnencryptedProperties::Set(const char* name,
61 t const& value)
62{
63 if (!OK()) return false;
64 std::ofstream o(folder_ + "/" + name);
65 o << value;
66 return !o.fail();
67}
68
69// Specialized getters/setters for strings
70template<> std::string UnencryptedProperties::Get(const char* name,
Paul Lawrencebc2eb8c2015-04-28 22:13:04 +000071 std::string default_value) const;
Paul Lawrence61980262015-03-16 15:35:55 -070072
73template<> bool UnencryptedProperties::Set(const char* name,
74 std::string const& value);