package gremlin

  1. Overview
  2. Docs
Gremlin Client Library

Install

Dune Dependency

Authors

Maintainers

Sources

0.1.1.tar.gz
md5=d6d34be20f43e9ff4c6b18159e99ea2c
sha512=42b39f19eb57d1f30b8e078457078e0d2dda35e538cc7fc28bc65d4cac6ebe8ad08f81fcd5f5e7e151c3cbfcd4ab9f9b09cba1608682fdda08eab0b5761b0bbe

README.md.html

OCaml Gremlin Client

Overview

This is a very rough Apache Tinkerpop3 Gremlin client library written in OCaml. It was implemented using the Graph Driver Provider Requirements.

Given this is my first public OCaml library and I was fairly rushed, it's not pretty.

I'd like to improve it which probably means completely refactoring it but I'm not sure when I'll get the chance. In the meantime, any suggestions or PRs are welcome.

Instructions

Build/Install

git clone https://github.com/bramford/ocaml-gremlin
cd ocaml-gremlin
opam pin add .

Usage

Assuming you're running a gremlin server on localhost:8182, in a toplevel such as utop:

#require "gremlin";;

let conn =
    Gremlin.Websocket.new_connection
    (Uri.of_string "http://localhost:8182/gremlin")

(* Add vertices *)
let add_vertices = Lwt_main.run (
  Gremlin.Websocket.run_queries_transaction
    conn
    ["g.addV('user').property('name', 'foo')";
    "g.addV('user').property('name', 'bar')";]
)

(* Get vertices *)
let get_vertices =
  Lwt_main.run (
    Gremlin.Websocket.run_query
      conn
      "g.V()"
  )
;;

See examples/ for other examples.

To do

There's obviously a lot to improve but here are some starting points:

  • [ ] Properly close gremlin session on completion

  • [ ] Handle streamed responses

  • [ ] Add interface documentation (e.g. odoc)

  • [ ] Implement proper logging (e.g. using Logs)

  • [ ] Improve types and results

  • [ ] Abstract internals and types properly

  • [ ] Refactor/improve response handler (currently uses Lwt_stream but poorly)

  • [ ] Refactor response JSON checking/parsing

  • [ ] Improve concurrency (currently all serial using Lwt_list.map_s)

  • [ ] Support other serialization formats (e.g. bytecode)

  • [ ] Support Traversal OpProcessor

  • [ ] Support REST interface

  • [ ] MirageOS compatibility