#pragma once #include #include #include #include "gflags/gflags.h" #include "data_structures/concurrent/concurrent_map.hpp" #include "database/graph_db.hpp" #include "database/graph_db_accessor.hpp" #include "durability/recovery.hpp" DECLARE_string(SNAPSHOT_DIRECTORY); DECLARE_bool(RECOVER_ON_STARTUP); namespace fs = std::experimental::filesystem; class Dbms { public: Dbms() { if (FLAGS_RECOVER_ON_STARTUP) { if (fs::exists(fs::path(FLAGS_SNAPSHOT_DIRECTORY))) { auto accessor = dbs.access(); for (auto &snapshot_db : fs::directory_iterator(FLAGS_SNAPSHOT_DIRECTORY)) { // create db and set it active active(snapshot_db.path().filename(), snapshot_db); } } } // create the default database and set is a active active("default"); } /** * Returns an accessor to the active database. */ std::unique_ptr active(); /** * Set the database with the given name to be active. * If there is no database with the given name, * it's created. If snapshooting is true, snapshooter starts * snapshooting on database creation. * * @return an accessor to the database with the given name. */ std::unique_ptr active( const std::string &name, const fs::path &snapshot_db_dir = fs::path()); // TODO: DELETE action private: // dbs container ConcurrentMap dbs; // currently active database std::atomic active_db; // // Cleaning thread. // TODO re-enable cleaning // Cleaning cleaning = {dbs, CONFIG_INTEGER(config::CLEANING_CYCLE_SEC)}; // // // Snapshoting thread. // TODO re-enable cleaning // Snapshoter snapshoter = {dbs, // CONFIG_INTEGER(config::SNAPSHOT_CYCLE_SEC)}; };