diff --git a/lib/neography/rest.rb b/lib/neography/rest.rb index 31ac33f..a71c197 100644 --- a/lib/neography/rest.rb +++ b/lib/neography/rest.rb @@ -13,36 +13,54 @@ class Rest def initialize(options = ENV['NEO4J_URL'] || {}) @connection = Connection.new(options) + + @nodes = Nodes.new(@connection) + @node_properties = NodeProperties.new(@connection) + @node_relationships = NodeRelationships.new(@connection) + @node_indexes = NodeIndexes.new(@connection) + @node_auto_indexes = NodeAutoIndexes.new(@connection) + @node_traversal = NodeTraversal.new(@connection) + @node_paths = NodePaths.new(@connection) + + @relationships = Relationships.new(@connection) + @relationship_properties = RelationshipProperties.new(@connection) + @relationship_indexes = RelationshipIndexes.new(@connection) + @relationship_auto_indexes = RelationshipAutoIndexes.new(@connection) + + @cypher = Cypher.new(@connection) + @gremlin = Gremlin.new(@connection) + @batch = Batch.new(@connection) + @clean = Clean.new(@connection) end # nodes def get_root - nodes.root + @nodes.root end def get_node(id) - nodes.get(id) + @nodes.get(id) end def get_nodes(*args) - nodes.get_each(*args) + @nodes.get_each(*args) end def create_node(*args) - nodes.create(*args) + @nodes.create(*args) end def create_nodes(args) - nodes.create_multiple(args) + @nodes.create_multiple(args) end def create_nodes_threaded(args) - nodes.create_multiple_threaded(args) + @nodes.create_multiple_threaded(args) end def delete_node(id) - nodes.delete(id) + @nodes.delete(id) end def delete_node!(id) @@ -64,29 +82,29 @@ def delete_node!(id) # node properties def get_node_properties(id, *properties) - node_properties.get(id, *properties.flatten) + @node_properties.get(id, *properties.flatten) end def set_node_properties(id, properties) - node_properties.set(id, properties) + @node_properties.set(id, properties) end def reset_node_properties(id, properties) - node_properties.reset(id, properties) + @node_properties.reset(id, properties) end def remove_node_properties(id, *properties) - node_properties.remove(id, *properties.flatten) + @node_properties.remove(id, *properties.flatten) end # relationships def get_relationship(id) - relationships.get(id) + @relationships.get(id) end def delete_relationship(id) - relationships.delete(id) + @relationships.delete(id) end def get_relationship_start_node(rel) @@ -100,203 +118,203 @@ def get_relationship_end_node(rel) # relationship properties def get_relationship_properties(id, *properties) - relationship_properties.get(id, *properties.flatten) + @relationship_properties.get(id, *properties.flatten) end def set_relationship_properties(id, properties) - relationship_properties.set(id, properties) + @relationship_properties.set(id, properties) end def reset_relationship_properties(id, properties) - relationship_properties.reset(id, properties) + @relationship_properties.reset(id, properties) end def remove_relationship_properties(id, *properties) - relationship_properties.remove(id, *properties.flatten) + @relationship_properties.remove(id, *properties.flatten) end # node relationships def get_node_relationships(id, dir = nil, types = nil) - node_relationships.get(id, dir, types) + @node_relationships.get(id, dir, types) end def create_relationship(type, from, to, props = nil) - node_relationships.create(type, from, to, props) + @node_relationships.create(type, from, to, props) end # node indexes def list_node_indexes - node_indexes.list + @node_indexes.list end alias_method :list_indexes, :list_node_indexes def create_node_index(name, type = "exact", provider = "lucene") - node_indexes.create(name, type, provider) + @node_indexes.create(name, type, provider) end def create_node_auto_index(type = "exact", provider = "lucene") - node_indexes.create_auto(type, provider) + @node_indexes.create_auto(type, provider) end def create_unique_node(index, key, value, props={}) - node_indexes.create_unique(index, key, value, props) + @node_indexes.create_unique(index, key, value, props) end def add_node_to_index(index, key, value, id) - node_indexes.add(index, key, value, id) + @node_indexes.add(index, key, value, id) end alias_method :add_to_index, :add_node_to_index def remove_node_from_index(index, id_or_key, id_or_value = nil, id = nil) - node_indexes.remove(index, id_or_key, id_or_value, id) + @node_indexes.remove(index, id_or_key, id_or_value, id) end alias_method :remove_from_index, :remove_node_from_index def get_node_index(index, key, value) - node_indexes.get(index, key, value) + @node_indexes.get(index, key, value) end alias_method :get_index, :get_node_index def find_node_index(index, key_or_query, value = nil) - node_indexes.find(index, key_or_query, value) + @node_indexes.find(index, key_or_query, value) end # auto node indexes def get_node_auto_index(key, value) - node_auto_indexes.get(key, value) + @node_auto_indexes.get(key, value) end def find_node_auto_index(key_or_query, value = nil) - node_auto_indexes.find_or_query(key_or_query, value) + @node_auto_indexes.find_or_query(key_or_query, value) end def get_node_auto_index_status - node_auto_indexes.status + @node_auto_indexes.status end def set_node_auto_index_status(change_to = true) - node_auto_indexes.status = change_to + @node_auto_indexes.status = change_to end def get_node_auto_index_properties - node_auto_indexes.properties + @node_auto_indexes.properties end def add_node_auto_index_property(property) - node_auto_indexes.add_property(property) + @node_auto_indexes.add_property(property) end def remove_node_auto_index_property(property) - node_auto_indexes.remove_property(property) + @node_auto_indexes.remove_property(property) end # relationship indexes def list_relationship_indexes - relationship_indexes.list + @relationship_indexes.list end def create_relationship_index(name, type = "exact", provider = "lucene") - relationship_indexes.create(name, type, provider) + @relationship_indexes.create(name, type, provider) end def create_relationship_auto_index(type = "exact", provider = "lucene") - relationship_indexes.create_auto(type, provider) + @relationship_indexes.create_auto(type, provider) end def create_unique_relationship(index, key, value, type, from, to) - relationship_indexes.create_unique(index, key, value, type, from, to) + @relationship_indexes.create_unique(index, key, value, type, from, to) end def add_relationship_to_index(index, key, value, id) - relationship_indexes.add(index, key, value, id) + @relationship_indexes.add(index, key, value, id) end def remove_relationship_from_index(index, id_or_key, id_or_value = nil, id = nil) - relationship_indexes.remove(index, id_or_key, id_or_value, id) + @relationship_indexes.remove(index, id_or_key, id_or_value, id) end def get_relationship_index(index, key, value) - relationship_indexes.get(index, key, value) + @relationship_indexes.get(index, key, value) end def find_relationship_index(index, key_or_query, value = nil) - relationship_indexes.find(index, key_or_query, value) + @relationship_indexes.find(index, key_or_query, value) end # relationship auto indexes def get_relationship_auto_index(key, value) - relationship_auto_indexes.get(key, value) + @relationship_auto_indexes.get(key, value) end def find_relationship_auto_index(key_or_query, value = nil) - relationship_auto_indexes.find_or_query(key_or_query, value) + @relationship_auto_indexes.find_or_query(key_or_query, value) end def get_relationship_auto_index_status - relationship_auto_indexes.status + @relationship_auto_indexes.status end def set_relationship_auto_index_status(change_to = true) - relationship_auto_indexes.status = change_to + @relationship_auto_indexes.status = change_to end def get_relationship_auto_index_properties - relationship_auto_indexes.properties + @relationship_auto_indexes.properties end def add_relationship_auto_index_property(property) - relationship_auto_indexes.add_property(property) + @relationship_auto_indexes.add_property(property) end def remove_relationship_auto_index_property(property) - relationship_auto_indexes.remove_property(property) + @relationship_auto_indexes.remove_property(property) end # traversal def traverse(id, return_type, description) - node_traversal.traverse(id, return_type, description) + @node_traversal.traverse(id, return_type, description) end # paths def get_path(from, to, relationships, depth = 1, algorithm = "shortestPath") - node_paths.get(from, to, relationships, depth, algorithm) + @node_paths.get(from, to, relationships, depth, algorithm) end def get_paths(from, to, relationships, depth = 1, algorithm = "allPaths") - node_paths.get_all(from, to, relationships, depth, algorithm) + @node_paths.get_all(from, to, relationships, depth, algorithm) end def get_shortest_weighted_path(from, to, relationships, weight_attr = "weight", depth = 1, algorithm = "dijkstra") - node_paths.shortest_weighted(from, to, relationships, weight_attr, depth, algorithm) + @node_paths.shortest_weighted(from, to, relationships, weight_attr, depth, algorithm) end # cypher query def execute_query(query, params = {}) - cypher.query(query, params) + @cypher.query(query, params) end # gremlin script def execute_script(script, params = {}) - gremlin.execute(script, params) + @gremlin.execute(script, params) end # batch def batch(*args) - batch_rest.execute(*args) + @batch.execute(*args) end def batch_not_streaming(*args) - batch_rest.not_streaming(*args) + @batch.not_streaming(*args) end # clean database @@ -305,74 +323,12 @@ def batch_not_streaming(*args) # call this before each test or spec def clean_database(sanity_check = "not_really") if sanity_check == "yes_i_really_want_to_clean_the_database" - clean.execute + @clean.execute true else false end end - private - - def nodes - @nodes ||= Nodes.new(@connection) - end - - def node_properties - @node_properties ||= NodeProperties.new(@connection) - end - - def node_relationships - @node_relationships ||= NodeRelationships.new(@connection) - end - - def node_indexes - @node_indexes ||= NodeIndexes.new(@connection) - end - - def node_auto_indexes - @node_auto_indexes ||= NodeAutoIndexes.new(@connection) - end - - def node_traversal - @node_traversal ||= NodeTraversal.new(@connection) - end - - def node_paths - @node_paths ||= NodePaths.new(@connection) - end - - def relationships - @relationships ||= Relationships.new(@connection) - end - - def relationship_properties - @relationship_properties ||= RelationshipProperties.new(@connection) - end - - def relationship_indexes - @relationship_indexes ||= RelationshipIndexes.new(@connection) - end - - def relationship_auto_indexes - @relationship_auto_indexes ||= RelationshipAutoIndexes.new(@connection) - end - - def cypher - @cypher ||= Cypher.new(@connection) - end - - def gremlin - @gremlin ||= Gremlin.new(@connection) - end - - def batch_rest - @batch ||= Batch.new(@connection) - end - - def clean - @clean ||= Clean.new(@connection) - end - end end