blob: d32e73207ee1e48000e3348ce2f79cda021d6b17 [file] [log] [blame]
Alex Deymoaea4c1c2015-08-19 20:24:43 -07001//
2// Copyright (C) 2012 The Android Open Source Project
3//
4// Licensed under the Apache License, Version 2.0 (the "License");
5// you may not use this file except in compliance with the License.
6// You may obtain a copy of the License at
7//
8// http://www.apache.org/licenses/LICENSE-2.0
9//
10// Unless required by applicable law or agreed to in writing, software
11// distributed under the License is distributed on an "AS IS" BASIS,
12// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13// See the License for the specific language governing permissions and
14// limitations under the License.
15//
Darin Petkov30030592010-07-27 13:53:20 -070016
Alex Deymo39910dc2015-11-09 17:04:30 -080017#ifndef UPDATE_ENGINE_COMMON_PREFS_H_
18#define UPDATE_ENGINE_COMMON_PREFS_H_
Darin Petkov30030592010-07-27 13:53:20 -070019
Kelvin Zhang1c86a922021-05-13 10:30:48 -040020#include <functional>
Alex Deymod6f60072015-10-12 12:22:27 -070021#include <map>
Alex Vakulenkod2779df2014-06-16 13:19:00 -070022#include <string>
Kelvin Zhangcf4600e2020-10-27 15:50:33 -040023#include <string_view>
Alex Deymod6f60072015-10-12 12:22:27 -070024#include <vector>
Alex Vakulenkod2779df2014-06-16 13:19:00 -070025
Alex Vakulenko75039d72014-03-25 12:36:28 -070026#include <base/files/file_path.h>
Alex Deymod6f60072015-10-12 12:22:27 -070027
Darin Petkov30030592010-07-27 13:53:20 -070028#include "gtest/gtest_prod.h" // for FRIEND_TEST
Alex Deymo39910dc2015-11-09 17:04:30 -080029#include "update_engine/common/prefs_interface.h"
Darin Petkov30030592010-07-27 13:53:20 -070030
31namespace chromeos_update_engine {
32
Alex Deymoa0284ac2016-07-22 12:51:41 -070033// Implements a preference store by storing the value associated with a key
34// in a given storage passed during construction.
35class PrefsBase : public PrefsInterface {
Darin Petkov30030592010-07-27 13:53:20 -070036 public:
Alex Deymoa0284ac2016-07-22 12:51:41 -070037 // Storage interface used to set and retrieve keys.
38 class StorageInterface {
39 public:
40 StorageInterface() = default;
41 virtual ~StorageInterface() = default;
Darin Petkov1cbd78f2010-07-29 12:38:34 -070042
Alex Deymoa0284ac2016-07-22 12:51:41 -070043 // Get the key named |key| and store its value in the referenced |value|.
44 // Returns whether the operation succeeded.
Kelvin Zhang1c86a922021-05-13 10:30:48 -040045 virtual bool GetKey(std::string_view key, std::string* value) const = 0;
Alex Deymoa0284ac2016-07-22 12:51:41 -070046
Jae Hoon Kim29a80e02020-05-11 20:18:49 -070047 // Get the keys stored within the namespace. If there are no keys in the
48 // namespace, |keys| will be empty. Returns whether the operation succeeded.
Kelvin Zhang1c86a922021-05-13 10:30:48 -040049 virtual bool GetSubKeys(std::string_view ns,
Jae Hoon Kim29a80e02020-05-11 20:18:49 -070050 std::vector<std::string>* keys) const = 0;
51
Alex Deymoa0284ac2016-07-22 12:51:41 -070052 // Set the value of the key named |key| to |value| regardless of the
53 // previous value. Returns whether the operation succeeded.
Kelvin Zhang1c86a922021-05-13 10:30:48 -040054 virtual bool SetKey(std::string_view key, std::string_view value) = 0;
Alex Deymoa0284ac2016-07-22 12:51:41 -070055
56 // Returns whether the key named |key| exists.
Kelvin Zhang1c86a922021-05-13 10:30:48 -040057 virtual bool KeyExists(std::string_view key) const = 0;
Alex Deymoa0284ac2016-07-22 12:51:41 -070058
59 // Deletes the value associated with the key name |key|. Returns whether the
60 // key was deleted.
Kelvin Zhang1c86a922021-05-13 10:30:48 -040061 virtual bool DeleteKey(std::string_view key) = 0;
Alex Deymoa0284ac2016-07-22 12:51:41 -070062
Daniel Zheng5eece042023-05-17 14:44:10 -070063 // Makes a copy of prefs directory called prefs_tmp, which is modified
64 // during update_engine checkpointing
65 virtual bool CreateTemporaryPrefs() { return false; }
66
67 // Deletes prefs_tmp directory
68 virtual bool DeleteTemporaryPrefs() { return false; }
69
70 // Replaces prefs with prefs_tmp to make update_engine checkpointing more
71 // atomic
72 virtual bool SwapPrefs() { return false; }
73
Alex Deymoa0284ac2016-07-22 12:51:41 -070074 private:
75 DISALLOW_COPY_AND_ASSIGN(StorageInterface);
76 };
77
78 explicit PrefsBase(StorageInterface* storage) : storage_(storage) {}
Darin Petkov30030592010-07-27 13:53:20 -070079
80 // PrefsInterface methods.
Kelvin Zhang1c86a922021-05-13 10:30:48 -040081 bool GetString(std::string_view key, std::string* value) const override;
82 bool SetString(std::string_view key, std::string_view value) override;
83 bool GetInt64(std::string_view key, int64_t* value) const override;
84 bool SetInt64(std::string_view key, const int64_t value) override;
85 bool GetBoolean(std::string_view key, bool* value) const override;
86 bool SetBoolean(std::string_view key, const bool value) override;
Daniel Zheng5eece042023-05-17 14:44:10 -070087 bool StartTransaction() override;
88 bool CancelTransaction() override;
89 bool SubmitTransaction() override;
Darin Petkov30030592010-07-27 13:53:20 -070090
Kelvin Zhang1c86a922021-05-13 10:30:48 -040091 bool Exists(std::string_view key) const override;
92 bool Delete(std::string_view key) override;
93 bool Delete(std::string_view pref_key,
Vyshu Khota4c5413d2020-11-04 16:17:25 -080094 const std::vector<std::string>& nss) override;
Jay Srinivasan480ddfa2012-06-01 19:15:26 -070095
Kelvin Zhang1c86a922021-05-13 10:30:48 -040096 bool GetSubKeys(std::string_view ns,
Jae Hoon Kim29a80e02020-05-11 20:18:49 -070097 std::vector<std::string>* keys) const override;
98
Kelvin Zhang1c86a922021-05-13 10:30:48 -040099 void AddObserver(std::string_view key, ObserverInterface* observer) override;
100 void RemoveObserver(std::string_view key,
Alex Deymod6f60072015-10-12 12:22:27 -0700101 ObserverInterface* observer) override;
102
Darin Petkov30030592010-07-27 13:53:20 -0700103 private:
Alex Deymoa0284ac2016-07-22 12:51:41 -0700104 // The registered observers watching for changes.
Kelvin Zhang1c86a922021-05-13 10:30:48 -0400105 std::map<std::string, std::vector<ObserverInterface*>, std::less<>>
106 observers_;
Alex Deymoa0284ac2016-07-22 12:51:41 -0700107
108 // The concrete implementation of the storage used for the keys.
109 StorageInterface* storage_;
110
111 DISALLOW_COPY_AND_ASSIGN(PrefsBase);
112};
113
114// Implements a preference store by storing the value associated with
115// a key in a separate file named after the key under a preference
116// store directory.
117
118class Prefs : public PrefsBase {
119 public:
120 Prefs() : PrefsBase(&file_storage_) {}
121
122 // Initializes the store by associating this object with |prefs_dir|
123 // as the preference store directory. Returns true on success, false
124 // otherwise.
125 bool Init(const base::FilePath& prefs_dir);
126
127 private:
Darin Petkov30030592010-07-27 13:53:20 -0700128 FRIEND_TEST(PrefsTest, GetFileNameForKey);
129 FRIEND_TEST(PrefsTest, GetFileNameForKeyBadCharacter);
130 FRIEND_TEST(PrefsTest, GetFileNameForKeyEmpty);
131
Alex Deymoa0284ac2016-07-22 12:51:41 -0700132 class FileStorage : public PrefsBase::StorageInterface {
133 public:
134 FileStorage() = default;
Darin Petkov30030592010-07-27 13:53:20 -0700135
Alex Deymoa0284ac2016-07-22 12:51:41 -0700136 bool Init(const base::FilePath& prefs_dir);
Darin Petkov1cbd78f2010-07-29 12:38:34 -0700137
Alex Deymoa0284ac2016-07-22 12:51:41 -0700138 // PrefsBase::StorageInterface overrides.
Kelvin Zhang1c86a922021-05-13 10:30:48 -0400139 bool GetKey(std::string_view key, std::string* value) const override;
140 bool GetSubKeys(std::string_view ns,
Jae Hoon Kim29a80e02020-05-11 20:18:49 -0700141 std::vector<std::string>* keys) const override;
Kelvin Zhang1c86a922021-05-13 10:30:48 -0400142 bool SetKey(std::string_view key, std::string_view value) override;
143 bool KeyExists(std::string_view key) const override;
144 bool DeleteKey(std::string_view key) override;
Daniel Zheng5eece042023-05-17 14:44:10 -0700145 bool CreateTemporaryPrefs() override;
146 bool DeleteTemporaryPrefs() override;
147 bool SwapPrefs() override;
Alex Deymoa0284ac2016-07-22 12:51:41 -0700148
149 private:
150 FRIEND_TEST(PrefsTest, GetFileNameForKey);
151 FRIEND_TEST(PrefsTest, GetFileNameForKeyBadCharacter);
152 FRIEND_TEST(PrefsTest, GetFileNameForKeyEmpty);
153
154 // Sets |filename| to the full path to the file containing the data
155 // associated with |key|. Returns true on success, false otherwise.
Kelvin Zhang1c86a922021-05-13 10:30:48 -0400156 bool GetFileNameForKey(std::string_view key,
Alex Deymoa0284ac2016-07-22 12:51:41 -0700157 base::FilePath* filename) const;
158
Daniel Zheng5eece042023-05-17 14:44:10 -0700159 // Returns path of prefs_tmp used during update_engine checkpointing
160 std::string GetTemporaryDir() const;
161
Alex Deymoa0284ac2016-07-22 12:51:41 -0700162 // Preference store directory.
163 base::FilePath prefs_dir_;
164 };
165
166 // The concrete file storage implementation.
167 FileStorage file_storage_;
Alex Deymod6f60072015-10-12 12:22:27 -0700168
Darin Petkov1cbd78f2010-07-29 12:38:34 -0700169 DISALLOW_COPY_AND_ASSIGN(Prefs);
Darin Petkov30030592010-07-27 13:53:20 -0700170};
171
Alex Deymoa0284ac2016-07-22 12:51:41 -0700172// Implements a preference store in memory. The stored values are lost when the
173// object is destroyed.
174
175class MemoryPrefs : public PrefsBase {
176 public:
177 MemoryPrefs() : PrefsBase(&mem_storage_) {}
178
179 private:
180 class MemoryStorage : public PrefsBase::StorageInterface {
181 public:
182 MemoryStorage() = default;
183
184 // PrefsBase::StorageInterface overrides.
Kelvin Zhang1c86a922021-05-13 10:30:48 -0400185 bool GetKey(std::string_view, std::string* value) const override;
186 bool GetSubKeys(std::string_view ns,
Jae Hoon Kim29a80e02020-05-11 20:18:49 -0700187 std::vector<std::string>* keys) const override;
Kelvin Zhang1c86a922021-05-13 10:30:48 -0400188 bool SetKey(std::string_view key, std::string_view value) override;
189 bool KeyExists(std::string_view key) const override;
190 bool DeleteKey(std::string_view key) override;
Alex Deymoa0284ac2016-07-22 12:51:41 -0700191
192 private:
193 // The std::map holding the values in memory.
Kelvin Zhang1c86a922021-05-13 10:30:48 -0400194 std::map<std::string, std::string, std::less<>> values_;
Alex Deymoa0284ac2016-07-22 12:51:41 -0700195 };
196
197 // The concrete memory storage implementation.
198 MemoryStorage mem_storage_;
199
200 DISALLOW_COPY_AND_ASSIGN(MemoryPrefs);
201};
Darin Petkov30030592010-07-27 13:53:20 -0700202} // namespace chromeos_update_engine
203
Alex Deymo39910dc2015-11-09 17:04:30 -0800204#endif // UPDATE_ENGINE_COMMON_PREFS_H_