| // |
| // Copyright (C) 2015 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 ATTESTATION_SERVER_DATABASE_IMPL_H_ |
| #define ATTESTATION_SERVER_DATABASE_IMPL_H_ |
| |
| #include "attestation/server/database.h" |
| |
| #include <string> |
| |
| #include <base/callback_forward.h> |
| #include <base/files/file_path_watcher.h> |
| #include <base/threading/thread_checker.h> |
| |
| #include "attestation/common/crypto_utility.h" |
| |
| namespace attestation { |
| |
| // An I/O abstraction to help with testing. |
| class DatabaseIO { |
| public: |
| // Reads the persistent database blob. |
| virtual bool Read(std::string* data) = 0; |
| // Writes the persistent database blob. |
| virtual bool Write(const std::string& data) = 0; |
| // Watch for external changes to the database. |
| virtual void Watch(const base::Closure& callback) = 0; |
| }; |
| |
| // An implementation of Database backed by an ordinary file. Not thread safe. |
| // All methods must be called on the same thread as the Initialize() call. |
| class DatabaseImpl : public Database, public DatabaseIO { |
| public: |
| // Does not take ownership of pointers. |
| explicit DatabaseImpl(CryptoUtility* crypto); |
| ~DatabaseImpl() override; |
| |
| // Reads and decrypts any existing database on disk synchronously. Must be |
| // called before calling other methods. |
| void Initialize(); |
| |
| // Database methods. |
| const AttestationDatabase& GetProtobuf() const override; |
| AttestationDatabase* GetMutableProtobuf() override; |
| bool SaveChanges() override; |
| bool Reload() override; |
| |
| // DatabaseIO methods. |
| bool Read(std::string* data) override; |
| bool Write(const std::string& data) override; |
| void Watch(const base::Closure& callback) override; |
| |
| // Useful for testing. |
| void set_io(DatabaseIO* io) { io_ = io; } |
| |
| private: |
| // Encrypts |protobuf_| into |encrypted_output|. Returns true on success. |
| bool EncryptProtobuf(std::string* encrypted_output); |
| |
| // Decrypts |encrypted_input| as output by EncryptProtobuf into |protobuf_|. |
| // Returns true on success. |
| bool DecryptProtobuf(const std::string& encrypted_input); |
| |
| AttestationDatabase protobuf_; |
| DatabaseIO* io_; |
| CryptoUtility* crypto_; |
| std::string database_key_; |
| std::string sealed_database_key_; |
| std::unique_ptr<base::FilePathWatcher> file_watcher_; |
| base::ThreadChecker thread_checker_; |
| }; |
| |
| } // namespace attestation |
| |
| #endif // ATTESTATION_SERVER_DATABASE_IMPL_H_ |