#pragma once #include #include "cppitertools/filter.hpp" #include "cppitertools/imap.hpp" #include "data_structures/concurrent/concurrent_set.hpp" #include "data_structures/concurrent/skiplist.hpp" #include "database/graph_db_datatypes.hpp" #include "database/indexes/key_index.hpp" #include "database/indexes/label_property_index.hpp" #include "durability/snapshooter.hpp" #include "mvcc/version_list.hpp" #include "storage/deferred_deleter.hpp" #include "storage/edge.hpp" #include "storage/garbage_collector.hpp" #include "storage/unique_object_store.hpp" #include "storage/vertex.hpp" #include "transactions/engine.hpp" #include "utils/scheduler.hpp" namespace fs = std::experimental::filesystem; // TODO: Maybe split this in another layer between Db and Dbms. Where the new // layer would hold SnapshotEngine and his kind of concept objects. Some // guidelines would be: retain objects which are necessary to implement querys // in Db, the rest can be moved to the new layer. /** * Main class which represents Database concept in code. * This class is essentially a data structure. It exposes * all the data publicly, and should therefore not be directly * exposed to client functions. The GraphDbAccessor is used for that. */ class GraphDb : public Loggable { public: /** * Construct database with a custom name. * * @param name database name * @param import_snapshot will in constructor import latest snapshot * into the db. */ GraphDb(const std::string &name, const fs::path &snapshot_db_dir); /** * @brief - Destruct database object. Delete all vertices and edges and free * all deferred deleters. */ ~GraphDb(); /** * Database object can't be copied. */ GraphDb(const GraphDb &db) = delete; /** * Starts database snapshooting. */ void StartSnapshooting(); /** * Recovers database from a snapshot file and starts snapshooting. * @param snapshot_db path to snapshot folder */ void RecoverDatabase(const fs::path &snapshot_db_path); /** transaction engine related to this database */ tx::Engine tx_engine; // database name // TODO consider if this is even necessary const std::string name_; // main storage for the graph SkipList *> vertices_; SkipList *> edges_; // Garbage collectors GarbageCollector gc_vertices_; GarbageCollector gc_edges_; // Deleters for not relevant records DeferredDeleter vertex_record_deleter_; DeferredDeleter edge_record_deleter_; // Deleters for not relevant version_lists DeferredDeleter> vertex_version_list_deleter_; DeferredDeleter> edge_version_list_deleter_; // unique object stores // TODO this should be also garbage collected ConcurrentSet labels_; ConcurrentSet edge_types_; ConcurrentSet properties_; // indexes KeyIndex labels_index_; KeyIndex edge_types_index_; LabelPropertyIndex label_property_index_; // snapshooter Snapshooter snapshooter_; // Schedulers Scheduler gc_scheduler_; Scheduler snapshot_creator_; };