2016-08-13 06:01:39 +08:00
|
|
|
#pragma once
|
|
|
|
|
2016-08-28 22:47:13 +08:00
|
|
|
#include "database/db.hpp"
|
2016-08-18 22:34:36 +08:00
|
|
|
#include "database/db_transaction.hpp"
|
2016-08-25 22:29:45 +08:00
|
|
|
#include "storage/model/properties/property_family.hpp"
|
2016-08-18 22:34:36 +08:00
|
|
|
#include "utils/border.hpp"
|
2016-08-28 22:47:13 +08:00
|
|
|
#include "utils/iterator/iterator.hpp"
|
2016-08-15 07:09:58 +08:00
|
|
|
#include "utils/option.hpp"
|
2016-08-13 06:01:39 +08:00
|
|
|
|
2016-08-18 22:34:36 +08:00
|
|
|
namespace tx
|
|
|
|
{
|
|
|
|
class Transaction;
|
|
|
|
}
|
|
|
|
|
2016-08-25 22:29:45 +08:00
|
|
|
class Label;
|
|
|
|
class EdgeType;
|
|
|
|
|
|
|
|
using EdgePropertyFamily = PropertyFamily<TypeGroupEdge>;
|
|
|
|
using VertexPropertyFamily = PropertyFamily<TypeGroupVertex>;
|
|
|
|
|
2016-08-15 07:09:58 +08:00
|
|
|
/*
|
|
|
|
* DbAccessor
|
|
|
|
* -Guarantees that access to Vertex and Edge is possible only through
|
2016-08-25 22:29:45 +08:00
|
|
|
* VertexAccessor and EdgeAccessor.
|
2016-08-15 07:09:58 +08:00
|
|
|
* -Guarantees that changing Vertex and Edge is possible only using
|
2016-08-25 22:29:45 +08:00
|
|
|
* VertexAccessor returned by vertex_insert() method and
|
|
|
|
* EdgeAccessor returned by edge_insert() method.
|
2016-08-15 07:09:58 +08:00
|
|
|
* -Offers CRUD for Vertex and Edge except iterating over all edges.
|
|
|
|
*
|
2016-08-25 22:29:45 +08:00
|
|
|
* VertexAccessor
|
2016-08-15 07:09:58 +08:00
|
|
|
* By default Vertex::accessor is empty. Caller has to call fill() method
|
|
|
|
* to fetch valid data and check it's return value. fill() method returns
|
|
|
|
* true if there is valid data for current transaction false otherwise.
|
|
|
|
* Only exception to this rule is vertex_insert() method in DbAccessor
|
2016-08-25 22:29:45 +08:00
|
|
|
* which returns by default filled VertexAccessor.
|
2016-08-15 07:09:58 +08:00
|
|
|
*
|
2016-08-25 22:29:45 +08:00
|
|
|
* EdgeAccessor
|
2016-08-15 07:09:58 +08:00
|
|
|
* By default Edge::accessor is empty. Caller has to call fill() method
|
|
|
|
* to
|
|
|
|
* fetch valid data and check it's return value. fill() method returns
|
|
|
|
* true
|
|
|
|
* if there is valid data for current transaction false otherwise.
|
|
|
|
* Only exception to this rule is edge_insert() method in DbAccessor
|
|
|
|
* which
|
2016-08-25 22:29:45 +08:00
|
|
|
* returns by default filled EdgeAccessor.
|
2016-08-15 07:09:58 +08:00
|
|
|
*/
|
2016-08-13 06:01:39 +08:00
|
|
|
class DbAccessor
|
|
|
|
{
|
2016-08-15 07:09:58 +08:00
|
|
|
|
2016-08-13 06:01:39 +08:00
|
|
|
public:
|
|
|
|
DbAccessor(Db &db);
|
|
|
|
|
2016-08-25 22:29:45 +08:00
|
|
|
DbAccessor(Db &db, tx::Transaction &t);
|
|
|
|
|
2016-08-15 07:09:58 +08:00
|
|
|
//*******************VERTEX METHODS
|
2016-08-28 22:47:13 +08:00
|
|
|
// TODO: Implement class specaily for this return
|
|
|
|
auto vertex_access()
|
|
|
|
{
|
|
|
|
return iter::make_map(
|
|
|
|
iter::make_iter(this->db_transaction.db.graph.vertices.access()),
|
|
|
|
[&](auto e) -> auto {
|
|
|
|
return VertexAccessor(&(e->second), db_transaction);
|
|
|
|
});
|
|
|
|
}
|
2016-08-13 06:01:39 +08:00
|
|
|
|
2016-08-25 22:29:45 +08:00
|
|
|
Option<const VertexAccessor> vertex_find(const Id &id);
|
2016-08-13 06:01:39 +08:00
|
|
|
|
2016-08-25 22:29:45 +08:00
|
|
|
// Creates new Vertex and returns filled VertexAccessor.
|
|
|
|
VertexAccessor vertex_insert();
|
2016-08-13 06:01:39 +08:00
|
|
|
|
2016-08-19 18:28:10 +08:00
|
|
|
// ******************* EDGE METHODS
|
2016-08-30 09:32:31 +08:00
|
|
|
auto edge_access()
|
|
|
|
{
|
|
|
|
return iter::make_map(
|
|
|
|
iter::make_iter(this->db_transaction.db.graph.edges.access()),
|
|
|
|
[&](auto e) -> auto {
|
|
|
|
return EdgeAccessor(&(e->second), db_transaction);
|
|
|
|
});
|
|
|
|
}
|
2016-08-15 07:09:58 +08:00
|
|
|
|
2016-08-25 22:29:45 +08:00
|
|
|
Option<const EdgeAccessor> edge_find(const Id &id);
|
2016-08-13 06:01:39 +08:00
|
|
|
|
2016-09-09 23:14:20 +08:00
|
|
|
// Creates new Edge and returns filled EdgeAccessor.
|
|
|
|
// Slighlty faster than const version.
|
|
|
|
EdgeAccessor edge_insert(VertexAccessor &from, VertexAccessor &to);
|
|
|
|
|
2016-08-25 22:29:45 +08:00
|
|
|
// Creates new Edge and returns filled EdgeAccessor.
|
|
|
|
EdgeAccessor edge_insert(VertexAccessor const &from,
|
|
|
|
VertexAccessor const &to);
|
2016-08-15 07:09:58 +08:00
|
|
|
|
2016-08-19 18:28:10 +08:00
|
|
|
// ******************* LABEL METHODS
|
2016-08-13 06:01:39 +08:00
|
|
|
|
2016-08-23 02:03:45 +08:00
|
|
|
const Label &label_find_or_create(const char *name);
|
2016-08-13 06:01:39 +08:00
|
|
|
|
2016-08-23 02:03:45 +08:00
|
|
|
bool label_contains(const char *name);
|
2016-08-13 06:01:39 +08:00
|
|
|
|
2016-08-19 18:28:10 +08:00
|
|
|
// ******************** TYPE METHODS
|
2016-08-13 06:01:39 +08:00
|
|
|
|
2016-08-23 02:03:45 +08:00
|
|
|
const EdgeType &type_find_or_create(const char *name);
|
2016-08-13 06:01:39 +08:00
|
|
|
|
2016-08-23 02:03:45 +08:00
|
|
|
bool type_contains(const char *name);
|
2016-08-13 06:01:39 +08:00
|
|
|
|
2016-08-19 18:28:10 +08:00
|
|
|
// ******************** PROPERTY METHODS
|
2016-08-18 22:34:36 +08:00
|
|
|
|
2016-08-25 22:29:45 +08:00
|
|
|
VertexPropertyFamily &vertex_property_family_get(const std::string &name);
|
2016-08-18 22:34:36 +08:00
|
|
|
|
2016-08-25 22:29:45 +08:00
|
|
|
EdgePropertyFamily &edge_property_family_get(const std::string &name);
|
2016-08-18 22:34:36 +08:00
|
|
|
|
2016-08-20 01:40:04 +08:00
|
|
|
// ******************** PROPERTY HELPER METHODS
|
2016-08-25 22:29:45 +08:00
|
|
|
VertexPropertyFamily::PropertyType::PropertyFamilyKey
|
2016-08-20 01:40:04 +08:00
|
|
|
vertex_property_key(const std::string &name, Type type);
|
|
|
|
|
2016-08-25 22:29:45 +08:00
|
|
|
EdgePropertyFamily::PropertyType::PropertyFamilyKey
|
2016-08-20 01:40:04 +08:00
|
|
|
edge_property_key(const std::string &name, Type type);
|
|
|
|
|
2016-08-25 22:29:45 +08:00
|
|
|
template <class T>
|
|
|
|
VertexPropertyFamily::PropertyType::PropertyTypeKey<T>
|
2016-08-28 22:47:13 +08:00
|
|
|
vertex_property_key(const std::string &name)
|
|
|
|
{
|
|
|
|
return vertex_property_family_get(name)
|
|
|
|
.get(T::type)
|
|
|
|
.template type_key<T>();
|
|
|
|
}
|
2016-08-25 22:29:45 +08:00
|
|
|
|
|
|
|
template <class T>
|
|
|
|
EdgePropertyFamily::PropertyType::PropertyTypeKey<T>
|
2016-08-28 22:47:13 +08:00
|
|
|
edge_property_key(const std::string &name)
|
|
|
|
{
|
|
|
|
return edge_property_family_get(name)
|
|
|
|
.get(T::type)
|
|
|
|
.template type_key<T>();
|
|
|
|
}
|
2016-08-25 22:29:45 +08:00
|
|
|
|
2016-08-19 18:28:10 +08:00
|
|
|
// ******************** TRANSACTION METHODS
|
2016-08-15 07:09:58 +08:00
|
|
|
|
2016-08-25 22:29:45 +08:00
|
|
|
// True if commit was successful, or false if transaction was aborted.
|
|
|
|
bool commit();
|
2016-08-13 06:01:39 +08:00
|
|
|
void abort();
|
|
|
|
|
2016-08-15 07:09:58 +08:00
|
|
|
private:
|
2016-08-25 22:29:45 +08:00
|
|
|
// TODO: make this friend generic for all indexes.
|
2016-08-18 22:34:36 +08:00
|
|
|
template <class T, class K>
|
|
|
|
friend class NonUniqueUnorderedIndex;
|
2016-08-25 22:29:45 +08:00
|
|
|
template <class T, class K>
|
|
|
|
friend class UniqueOrderedIndex;
|
2016-08-13 06:01:39 +08:00
|
|
|
|
2016-08-18 22:34:36 +08:00
|
|
|
DbTransaction db_transaction;
|
2016-08-13 06:01:39 +08:00
|
|
|
};
|
2016-08-15 07:09:58 +08:00
|
|
|
|
2016-08-19 18:28:10 +08:00
|
|
|
// ********************** CONVENIENT FUNCTIONS
|
2016-08-15 07:09:58 +08:00
|
|
|
|
|
|
|
template <class R>
|
|
|
|
bool option_fill(Option<R> &o)
|
|
|
|
{
|
|
|
|
return o.is_present() && o.get().fill();
|
|
|
|
}
|