//
// 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_