cayley-ruby

A ruby library for working with Google's Cayley graph database.

Installation

You can install it via gem

gem install cayley

Usage

Start your Cayley

# example using 30kmoviedata from cayley's repository
./cayley http --dbpath=30kmoviedata.nq.gz

You can use methods from Gremlin API documentation, just translate method names to snake style equivalent.

As a first step you need to create your client

require 'cayley'

graph = Cayley::Graph.new

# or

graph = Cayley::Graph.new(host: 'localhost', port: 64210)

Then using 30kmovies.nt db from cayley's repository you can do this

graph.vertex.get_limit(5)

graph.vertex('Humphrey Bogart').all

graph.v('Humphrey Bogart').all

graph.v('Humphrey Bogart').in('name').all

graph.v('Casablanca').in('name').all

graph.v.has('name', 'Casablanca').all

You can also use morphism

film_to_actor = graph.morphism
                     .out('/film/film/starring')
                     .out('/film/performance/actor')
graph.v
     .has('name', 'Casablanca')
     .follow(film_to_actor)
     .out('name').all

For more info take a look at Cayley's repository

Advanced

By default result of your queries are wrapped in Hashie::Mash so you can do things like these

graph.v.all.each do |result|
  puts result.id # instead of result['id']
end

If you want to use plain ruby hashes you can disable wrapping by

graph = Cayley::Graph.new(result_wrapper: nil)

Or you can use some custom wrapper if you put class instead of nil.

Debugging

If you are not sure why you are getting nil as a result of your query and you are not able to find out the solution you can turn on debug mode where used Gremlin query is printed out.

graph = Cayley::Graph.new(debug: true)

TODO

  • logger
  • tests