3.2.5-SNAPSHOT
IO Reference
IO features, capabilities and use cases are initially discussed in the TinkerPop Reference Documentation. This document focuses more on the details of the implementations for both production and consumption of the various formats. It contains samples of the various formats and development details that provide deeper insight for their usage.
GraphML
The GraphML file format is a common XML-based representation of a graph. It uses an edge list format where vertices and their properties are listed and edges and their properties are listed by referencing the in and out vertices for each edge. GraphML does support a number of features which are not implemented by TinkerPop (e.g. extending GraphML with custom types) and there are features of TinkerPop that are not supported by GraphML (e.g. meta-properties), but GraphML does represent the most universal way to consume or produce a graph for integration with other systems as GraphML tends to have fairly wide support.
In TinkerPop, GraphML is also not extended for purpose of serializing just any type (i.e. serialize just a Vertex
to
XML). It is only supported for a Graph
instance.
The following example is a representation of the Modern toy graph in GraphML:
<?xml version="1.0" encoding="UTF-8"?>
<graphml xmlns="http://graphml.graphdrawing.org/xmlns" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://graphml.graphdrawing.org/xmlns http://graphml.graphdrawing.org/xmlns/1.1/graphml.xsd">
<key id="labelV" for="node" attr.name="labelV" attr.type="string" />
<key id="name" for="node" attr.name="name" attr.type="string" />
<key id="lang" for="node" attr.name="lang" attr.type="string" />
<key id="age" for="node" attr.name="age" attr.type="int" />
<key id="labelE" for="edge" attr.name="labelE" attr.type="string" />
<key id="weight" for="edge" attr.name="weight" attr.type="double" />
<graph id="G" edgedefault="directed">
<node id="1">
<data key="labelV">person</data>
<data key="name">marko</data>
<data key="age">29</data>
</node>
<node id="2">
<data key="labelV">person</data>
<data key="name">vadas</data>
<data key="age">27</data>
</node>
<node id="3">
<data key="labelV">software</data>
<data key="name">lop</data>
<data key="lang">java</data>
</node>
<node id="4">
<data key="labelV">person</data>
<data key="name">josh</data>
<data key="age">32</data>
</node>
<node id="5">
<data key="labelV">software</data>
<data key="name">ripple</data>
<data key="lang">java</data>
</node>
<node id="6">
<data key="labelV">person</data>
<data key="name">peter</data>
<data key="age">35</data>
</node>
<edge id="7" source="1" target="2">
<data key="labelE">knows</data>
<data key="weight">0.5</data>
</edge>
<edge id="8" source="1" target="4">
<data key="labelE">knows</data>
<data key="weight">1.0</data>
</edge>
<edge id="9" source="1" target="3">
<data key="labelE">created</data>
<data key="weight">0.4</data>
</edge>
<edge id="10" source="4" target="5">
<data key="labelE">created</data>
<data key="weight">1.0</data>
</edge>
<edge id="11" source="4" target="3">
<data key="labelE">created</data>
<data key="weight">0.4</data>
</edge>
<edge id="12" source="6" target="3">
<data key="labelE">created</data>
<data key="weight">0.2</data>
</edge>
</graph>
</graphml>
Consider the following points when reading a GraphML file to TinkerPop that was generated outside of TinkerPop:
-
Supports the following values in
attr.type
:-
string
-
float
-
double
-
int
-
long
-
boolean
-
-
Does not currently support the
<default>
tag in the schema definitions. -
The GraphML will be read as a directed graph regardless of the value supplied
edgedefault
setting in the<graph>
tag as that is the nature of the type of graph that TinkerPop supports. -
The vertex and edge
id
values will always be treated as aString
if theGraph
instance consuming the data supports user-supplied identifiers (i.e. TinkerGraph). -
By default the labels for vertex and edges are referred to as "labelV" and "labelE" respectively. It is possible to change these defaults on the
Builder
for theGraphReader
. If no label is supplied, the reader will default to "vertex" and "edge" respectively as is the general expectation in TinkerPop when those values are omitted.
GraphSON
GraphSON is a JSON-based format that is designed for human readable output that is easily supported in any programming language through the wide-array of JSON parsing libraries that exist on virtually all platforms. GraphSON is considered both a "graph" format and a generalized object serialization format. That characteristic makes it useful as a serialization format for Gremlin Server where arbitrary objects of varying types may be returned as results.
When considering GraphSON as a "graph" format, the relevant feature to consider is the writeGraph
and readGraph
methods on the GraphSONWriter
and GraphSONReader
interfaces, respectively. These methods write the entire Graph
instance as output or read an entire Graph
instance input and they do so in a way external to generalized object
serialization. In other words, the output of:
final Graph graph = TinkerFactory.createModern();
final GraphWriter writer = graph.io(IoCore.graphson()).writer();
writer.writeGraph("tinkerpop-modern.json");
will be different of:
final Graph graph = TinkerFactory.createModern();
final GraphWriter writer = graph.io(IoCore.graphson()).writer();
final OutputStream os = new FileOutputStream("tinkerpop-modern.json");
writer.writeObject(os, graph);
Generalized object serialization will be discussed later in this section, so for now the focus will be on the "graph" format. Unlike GraphML, GraphSON does not use an edge list format. It uses an adjacency list. In the adjacency list, each vertex is essentially a line in the file and the vertex line contains a list of all the edges associated with that vertex. The GraphSON 2.0 representation looks like this for the Modern toy graph:
{"id":{"@type":"g:Int32","@value":1},"label":"person","outE":{"created":[{"id":{"@type":"g:Int32","@value":9},"inV":{"@type":"g:Int32","@value":3},"properties":{"weight":{"@type":"g:Double","@value":0.4}}}],"knows":[{"id":{"@type":"g:Int32","@value":7},"inV":{"@type":"g:Int32","@value":2},"properties":{"weight":{"@type":"g:Double","@value":0.5}}},{"id":{"@type":"g:Int32","@value":8},"inV":{"@type":"g:Int32","@value":4},"properties":{"weight":{"@type":"g:Double","@value":1.0}}}]},"properties":{"name":[{"id":{"@type":"g:Int64","@value":0},"value":"marko"}],"age":[{"id":{"@type":"g:Int64","@value":1},"value":{"@type":"g:Int32","@value":29}}]}}
{"id":{"@type":"g:Int32","@value":2},"label":"person","inE":{"knows":[{"id":{"@type":"g:Int32","@value":7},"outV":{"@type":"g:Int32","@value":1},"properties":{"weight":{"@type":"g:Double","@value":0.5}}}]},"properties":{"name":[{"id":{"@type":"g:Int64","@value":2},"value":"vadas"}],"age":[{"id":{"@type":"g:Int64","@value":3},"value":{"@type":"g:Int32","@value":27}}]}}
{"id":{"@type":"g:Int32","@value":3},"label":"software","inE":{"created":[{"id":{"@type":"g:Int32","@value":9},"outV":{"@type":"g:Int32","@value":1},"properties":{"weight":{"@type":"g:Double","@value":0.4}}},{"id":{"@type":"g:Int32","@value":11},"outV":{"@type":"g:Int32","@value":4},"properties":{"weight":{"@type":"g:Double","@value":0.4}}},{"id":{"@type":"g:Int32","@value":12},"outV":{"@type":"g:Int32","@value":6},"properties":{"weight":{"@type":"g:Double","@value":0.2}}}]},"properties":{"name":[{"id":{"@type":"g:Int64","@value":4},"value":"lop"}],"lang":[{"id":{"@type":"g:Int64","@value":5},"value":"java"}]}}
{"id":{"@type":"g:Int32","@value":4},"label":"person","inE":{"knows":[{"id":{"@type":"g:Int32","@value":8},"outV":{"@type":"g:Int32","@value":1},"properties":{"weight":{"@type":"g:Double","@value":1.0}}}]},"outE":{"created":[{"id":{"@type":"g:Int32","@value":10},"inV":{"@type":"g:Int32","@value":5},"properties":{"weight":{"@type":"g:Double","@value":1.0}}},{"id":{"@type":"g:Int32","@value":11},"inV":{"@type":"g:Int32","@value":3},"properties":{"weight":{"@type":"g:Double","@value":0.4}}}]},"properties":{"name":[{"id":{"@type":"g:Int64","@value":6},"value":"josh"}],"age":[{"id":{"@type":"g:Int64","@value":7},"value":{"@type":"g:Int32","@value":32}}]}}
{"id":{"@type":"g:Int32","@value":5},"label":"software","inE":{"created":[{"id":{"@type":"g:Int32","@value":10},"outV":{"@type":"g:Int32","@value":4},"properties":{"weight":{"@type":"g:Double","@value":1.0}}}]},"properties":{"name":[{"id":{"@type":"g:Int64","@value":8},"value":"ripple"}],"lang":[{"id":{"@type":"g:Int64","@value":9},"value":"java"}]}}
{"id":{"@type":"g:Int32","@value":6},"label":"person","outE":{"created":[{"id":{"@type":"g:Int32","@value":12},"inV":{"@type":"g:Int32","@value":3},"properties":{"weight":{"@type":"g:Double","@value":0.2}}}]},"properties":{"name":[{"id":{"@type":"g:Int64","@value":10},"value":"peter"}],"age":[{"id":{"@type":"g:Int64","@value":11},"value":{"@type":"g:Int32","@value":35}}]}}
At a glance, one can see that this is not a valid JSON document. While that may seem incorrect, there is a reason. The
"graph" format is designed by default to be splittable, such that distributed systems like Spark can easily divide the
a GraphSON file for processing. If this data were represented as an "array of vertices" with square brackets at the
beginning and end of the file, the format would be less conducive to fit that purpose. It is possible to change this
behavior by building the GraphSONWriter
with the wrapAdjacencyList
setting set to true
, in which case the output
will be a valid JSON document that looks like this:
{ "vertices": [
{"id":{"@type":"g:Int32","@value":1},"label":"person","outE":{"created":[{"id":{"@type":"g:Int32","@value":9},"inV":{"@type":"g:Int32","@value":3},"properties":{"weight":{"@type":"g:Double","@value":0.4}}}],"knows":[{"id":{"@type":"g:Int32","@value":7},"inV":{"@type":"g:Int32","@value":2},"properties":{"weight":{"@type":"g:Double","@value":0.5}}},{"id":{"@type":"g:Int32","@value":8},"inV":{"@type":"g:Int32","@value":4},"properties":{"weight":{"@type":"g:Double","@value":1.0}}}]},"properties":{"name":[{"id":{"@type":"g:Int64","@value":0},"value":"marko"}],"age":[{"id":{"@type":"g:Int64","@value":1},"value":{"@type":"g:Int32","@value":29}}]}}
{"id":{"@type":"g:Int32","@value":2},"label":"person","inE":{"knows":[{"id":{"@type":"g:Int32","@value":7},"outV":{"@type":"g:Int32","@value":1},"properties":{"weight":{"@type":"g:Double","@value":0.5}}}]},"properties":{"name":[{"id":{"@type":"g:Int64","@value":2},"value":"vadas"}],"age":[{"id":{"@type":"g:Int64","@value":3},"value":{"@type":"g:Int32","@value":27}}]}}
{"id":{"@type":"g:Int32","@value":3},"label":"software","inE":{"created":[{"id":{"@type":"g:Int32","@value":9},"outV":{"@type":"g:Int32","@value":1},"properties":{"weight":{"@type":"g:Double","@value":0.4}}},{"id":{"@type":"g:Int32","@value":11},"outV":{"@type":"g:Int32","@value":4},"properties":{"weight":{"@type":"g:Double","@value":0.4}}},{"id":{"@type":"g:Int32","@value":12},"outV":{"@type":"g:Int32","@value":6},"properties":{"weight":{"@type":"g:Double","@value":0.2}}}]},"properties":{"name":[{"id":{"@type":"g:Int64","@value":4},"value":"lop"}],"lang":[{"id":{"@type":"g:Int64","@value":5},"value":"java"}]}}
{"id":{"@type":"g:Int32","@value":4},"label":"person","inE":{"knows":[{"id":{"@type":"g:Int32","@value":8},"outV":{"@type":"g:Int32","@value":1},"properties":{"weight":{"@type":"g:Double","@value":1.0}}}]},"outE":{"created":[{"id":{"@type":"g:Int32","@value":10},"inV":{"@type":"g:Int32","@value":5},"properties":{"weight":{"@type":"g:Double","@value":1.0}}},{"id":{"@type":"g:Int32","@value":11},"inV":{"@type":"g:Int32","@value":3},"properties":{"weight":{"@type":"g:Double","@value":0.4}}}]},"properties":{"name":[{"id":{"@type":"g:Int64","@value":6},"value":"josh"}],"age":[{"id":{"@type":"g:Int64","@value":7},"value":{"@type":"g:Int32","@value":32}}]}}
{"id":{"@type":"g:Int32","@value":5},"label":"software","inE":{"created":[{"id":{"@type":"g:Int32","@value":10},"outV":{"@type":"g:Int32","@value":4},"properties":{"weight":{"@type":"g:Double","@value":1.0}}}]},"properties":{"name":[{"id":{"@type":"g:Int64","@value":8},"value":"ripple"}],"lang":[{"id":{"@type":"g:Int64","@value":9},"value":"java"}]}}
{"id":{"@type":"g:Int32","@value":6},"label":"person","outE":{"created":[{"id":{"@type":"g:Int32","@value":12},"inV":{"@type":"g:Int32","@value":3},"properties":{"weight":{"@type":"g:Double","@value":0.2}}}]},"properties":{"name":[{"id":{"@type":"g:Int64","@value":10},"value":"peter"}],"age":[{"id":{"@type":"g:Int64","@value":11},"value":{"@type":"g:Int32","@value":35}}]}}
]}
Note
|
The writeGraph method essentially calls writeVertices with the directionality of BOTH . The writeVertices
method simply calls writeVertex which detaches each Vertex instance into a directional StarGraph which forms
the basis for the format.
|
The following sections discuss the GraphSON object serialization format as available in each version of GraphSON. Core to understanding these sections is to understand that GraphSON can be produced with and without types being embedded in the output. Without embedded types, the type system is restricted to standard JSON types of Object, List, String, Number, Boolean and that will lead to "lossyness" in the format (i.e. a float will be interpreted as double).
Version 1.0
Version 1.0 of GraphSON was released with TinkerPop 3.0.0. When types are embedded, GraphSON uses the standard Jackson type embedding approach that writes the full Java class name into a "@class" field in the JSON. While this approach isn’t especially language agnostic it does at least give some hint as to what the expected type is.
This section focuses on non-embedded types and their formats as there was little usage of embedded types in generalized object serialization use cases. The format was simply too cumbersome to parse of non-Jackson enabled libraries and the use cases for it were limited. GraphSON Version 2.0 attempts to improve upon this limitation.
Graph Structure
Edge
{
"id" : 13,
"label" : "develops",
"type" : "edge",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : 10,
"outV" : 1,
"properties" : {
"since" : 2009
}
}
Path
{
"labels" : [ [ ], [ ], [ ] ],
"objects" : [ {
"id" : 1,
"label" : "person",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 0,
"value" : "marko"
} ],
"location" : [ {
"id" : 6,
"value" : "san diego",
"properties" : {
"startTime" : 1997,
"endTime" : 2001
}
}, {
"id" : 7,
"value" : "santa cruz",
"properties" : {
"startTime" : 2001,
"endTime" : 2004
}
}, {
"id" : 8,
"value" : "brussels",
"properties" : {
"startTime" : 2004,
"endTime" : 2005
}
}, {
"id" : 9,
"value" : "santa fe",
"properties" : {
"startTime" : 2005
}
} ]
}
}, {
"id" : 10,
"label" : "software",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 4,
"value" : "gremlin"
} ]
}
}, {
"id" : 11,
"label" : "software",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 5,
"value" : "tinkergraph"
} ]
}
} ]
}
Property
{
"key" : "since",
"value" : 2009
}
StarGraph
{
"id" : 1,
"label" : "person",
"outE" : {
"uses" : [ {
"id" : 16,
"inV" : 11,
"properties" : {
"skill" : 5
}
}, {
"id" : 15,
"inV" : 10,
"properties" : {
"skill" : 4
}
} ],
"develops" : [ {
"id" : 13,
"inV" : 10,
"properties" : {
"since" : 2009
}
}, {
"id" : 14,
"inV" : 11,
"properties" : {
"since" : 2010
}
} ]
},
"properties" : {
"name" : [ {
"id" : 0,
"value" : "marko"
} ],
"location" : [ {
"id" : 6,
"value" : "san diego",
"properties" : {
"startTime" : 1997,
"endTime" : 2001
}
}, {
"id" : 7,
"value" : "santa cruz",
"properties" : {
"startTime" : 2001,
"endTime" : 2004
}
}, {
"id" : 8,
"value" : "brussels",
"properties" : {
"startTime" : 2004,
"endTime" : 2005
}
}, {
"id" : 9,
"value" : "santa fe",
"properties" : {
"startTime" : 2005
}
} ]
}
}
TinkerGraph
TinkerGraph
has a custom serializer that is registered as part of the TinkerIoRegistry
.
{
"vertices" : [ {
"id" : 1,
"label" : "person",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 0,
"value" : "marko"
} ],
"location" : [ {
"id" : 6,
"value" : "san diego",
"properties" : {
"startTime" : 1997,
"endTime" : 2001
}
}, {
"id" : 7,
"value" : "santa cruz",
"properties" : {
"startTime" : 2001,
"endTime" : 2004
}
}, {
"id" : 8,
"value" : "brussels",
"properties" : {
"startTime" : 2004,
"endTime" : 2005
}
}, {
"id" : 9,
"value" : "santa fe",
"properties" : {
"startTime" : 2005
}
} ]
}
}, {
"id" : 7,
"label" : "person",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 1,
"value" : "stephen"
} ],
"location" : [ {
"id" : 10,
"value" : "centreville",
"properties" : {
"startTime" : 1990,
"endTime" : 2000
}
}, {
"id" : 11,
"value" : "dulles",
"properties" : {
"startTime" : 2000,
"endTime" : 2006
}
}, {
"id" : 12,
"value" : "purcellville",
"properties" : {
"startTime" : 2006
}
} ]
}
}, {
"id" : 8,
"label" : "person",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 2,
"value" : "matthias"
} ],
"location" : [ {
"id" : 13,
"value" : "bremen",
"properties" : {
"startTime" : 2004,
"endTime" : 2007
}
}, {
"id" : 14,
"value" : "baltimore",
"properties" : {
"startTime" : 2007,
"endTime" : 2011
}
}, {
"id" : 15,
"value" : "oakland",
"properties" : {
"startTime" : 2011,
"endTime" : 2014
}
}, {
"id" : 16,
"value" : "seattle",
"properties" : {
"startTime" : 2014
}
} ]
}
}, {
"id" : 9,
"label" : "person",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 3,
"value" : "daniel"
} ],
"location" : [ {
"id" : 17,
"value" : "spremberg",
"properties" : {
"startTime" : 1982,
"endTime" : 2005
}
}, {
"id" : 18,
"value" : "kaiserslautern",
"properties" : {
"startTime" : 2005,
"endTime" : 2009
}
}, {
"id" : 19,
"value" : "aachen",
"properties" : {
"startTime" : 2009
}
} ]
}
}, {
"id" : 10,
"label" : "software",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 4,
"value" : "gremlin"
} ]
}
}, {
"id" : 11,
"label" : "software",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 5,
"value" : "tinkergraph"
} ]
}
} ],
"edges" : [ {
"id" : 13,
"label" : "develops",
"type" : "edge",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : 10,
"outV" : 1,
"properties" : {
"since" : 2009
}
}, {
"id" : 14,
"label" : "develops",
"type" : "edge",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : 11,
"outV" : 1,
"properties" : {
"since" : 2010
}
}, {
"id" : 15,
"label" : "uses",
"type" : "edge",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : 10,
"outV" : 1,
"properties" : {
"skill" : 4
}
}, {
"id" : 16,
"label" : "uses",
"type" : "edge",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : 11,
"outV" : 1,
"properties" : {
"skill" : 5
}
}, {
"id" : 17,
"label" : "develops",
"type" : "edge",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : 10,
"outV" : 7,
"properties" : {
"since" : 2010
}
}, {
"id" : 18,
"label" : "develops",
"type" : "edge",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : 11,
"outV" : 7,
"properties" : {
"since" : 2011
}
}, {
"id" : 19,
"label" : "uses",
"type" : "edge",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : 10,
"outV" : 7,
"properties" : {
"skill" : 5
}
}, {
"id" : 20,
"label" : "uses",
"type" : "edge",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : 11,
"outV" : 7,
"properties" : {
"skill" : 4
}
}, {
"id" : 21,
"label" : "develops",
"type" : "edge",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : 10,
"outV" : 8,
"properties" : {
"since" : 2012
}
}, {
"id" : 22,
"label" : "uses",
"type" : "edge",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : 10,
"outV" : 8,
"properties" : {
"skill" : 3
}
}, {
"id" : 23,
"label" : "uses",
"type" : "edge",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : 11,
"outV" : 8,
"properties" : {
"skill" : 3
}
}, {
"id" : 24,
"label" : "uses",
"type" : "edge",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : 10,
"outV" : 9,
"properties" : {
"skill" : 5
}
}, {
"id" : 25,
"label" : "uses",
"type" : "edge",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : 11,
"outV" : 9,
"properties" : {
"skill" : 3
}
}, {
"id" : 26,
"label" : "traverses",
"type" : "edge",
"inVLabel" : "software",
"outVLabel" : "software",
"inV" : 11,
"outV" : 10
} ]
}
Tree
{
"1" : {
"key" : {
"id" : 1,
"label" : "person",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 0,
"value" : "marko"
} ],
"location" : [ {
"id" : 6,
"value" : "san diego",
"properties" : {
"startTime" : 1997,
"endTime" : 2001
}
}, {
"id" : 7,
"value" : "santa cruz",
"properties" : {
"startTime" : 2001,
"endTime" : 2004
}
}, {
"id" : 8,
"value" : "brussels",
"properties" : {
"startTime" : 2004,
"endTime" : 2005
}
}, {
"id" : 9,
"value" : "santa fe",
"properties" : {
"startTime" : 2005
}
} ]
}
},
"value" : {
"10" : {
"key" : {
"id" : 10,
"label" : "software",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 4,
"value" : "gremlin"
} ]
}
},
"value" : {
"11" : {
"key" : {
"id" : 11,
"label" : "software",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 5,
"value" : "tinkergraph"
} ]
}
},
"value" : { }
}
}
}
}
},
"7" : {
"key" : {
"id" : 7,
"label" : "person",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 1,
"value" : "stephen"
} ],
"location" : [ {
"id" : 10,
"value" : "centreville",
"properties" : {
"startTime" : 1990,
"endTime" : 2000
}
}, {
"id" : 11,
"value" : "dulles",
"properties" : {
"startTime" : 2000,
"endTime" : 2006
}
}, {
"id" : 12,
"value" : "purcellville",
"properties" : {
"startTime" : 2006
}
} ]
}
},
"value" : {
"10" : {
"key" : {
"id" : 10,
"label" : "software",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 4,
"value" : "gremlin"
} ]
}
},
"value" : {
"11" : {
"key" : {
"id" : 11,
"label" : "software",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 5,
"value" : "tinkergraph"
} ]
}
},
"value" : { }
}
}
}
}
},
"8" : {
"key" : {
"id" : 8,
"label" : "person",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 2,
"value" : "matthias"
} ],
"location" : [ {
"id" : 13,
"value" : "bremen",
"properties" : {
"startTime" : 2004,
"endTime" : 2007
}
}, {
"id" : 14,
"value" : "baltimore",
"properties" : {
"startTime" : 2007,
"endTime" : 2011
}
}, {
"id" : 15,
"value" : "oakland",
"properties" : {
"startTime" : 2011,
"endTime" : 2014
}
}, {
"id" : 16,
"value" : "seattle",
"properties" : {
"startTime" : 2014
}
} ]
}
},
"value" : {
"10" : {
"key" : {
"id" : 10,
"label" : "software",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 4,
"value" : "gremlin"
} ]
}
},
"value" : {
"11" : {
"key" : {
"id" : 11,
"label" : "software",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 5,
"value" : "tinkergraph"
} ]
}
},
"value" : { }
}
}
}
}
},
"9" : {
"key" : {
"id" : 9,
"label" : "person",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 3,
"value" : "daniel"
} ],
"location" : [ {
"id" : 17,
"value" : "spremberg",
"properties" : {
"startTime" : 1982,
"endTime" : 2005
}
}, {
"id" : 18,
"value" : "kaiserslautern",
"properties" : {
"startTime" : 2005,
"endTime" : 2009
}
}, {
"id" : 19,
"value" : "aachen",
"properties" : {
"startTime" : 2009
}
} ]
}
},
"value" : {
"10" : {
"key" : {
"id" : 10,
"label" : "software",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 4,
"value" : "gremlin"
} ]
}
},
"value" : {
"11" : {
"key" : {
"id" : 11,
"label" : "software",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 5,
"value" : "tinkergraph"
} ]
}
},
"value" : { }
}
}
}
}
}
}
Vertex
{
"id" : 1,
"label" : "person",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 0,
"value" : "marko"
} ],
"location" : [ {
"id" : 6,
"value" : "san diego",
"properties" : {
"startTime" : 1997,
"endTime" : 2001
}
}, {
"id" : 7,
"value" : "santa cruz",
"properties" : {
"startTime" : 2001,
"endTime" : 2004
}
}, {
"id" : 8,
"value" : "brussels",
"properties" : {
"startTime" : 2004,
"endTime" : 2005
}
}, {
"id" : 9,
"value" : "santa fe",
"properties" : {
"startTime" : 2005
}
} ]
}
}
VertexProperty
{
"id" : 0,
"value" : "marko",
"label" : "name"
}
RequestMessage
Authentication Response
The following RequestMessage
is an example of the response that should be made to a SASL-based authentication challenge.
{
"requestId" : "e943a111-a9f4-4fbd-bc47-28c5e01de67e",
"op" : "authentication",
"processor" : "",
"args" : {
"saslMechanism" : "PLAIN",
"sasl" : "AHN0ZXBocGhlbgBwYXNzd29yZA=="
}
}
Session Eval
The following RequestMessage
is an example of a simple session request for a script evaluation with parameters.
{
"requestId" : "5d7e3354-cd29-47eb-b14a-d6fcc973e58e",
"op" : "eval",
"processor" : "session",
"args" : {
"gremlin" : "g.V(x)",
"language" : "gremlin-groovy",
"session" : "41d2e28a-20a4-4ab0-b379-d810dede3786",
"bindings" : {
"x" : 1
}
}
}
Session Eval
The following RequestMessage
is an example of a session request for a script evaluation with an alias that binds the TraversalSource
of "g" to "social".
{
"requestId" : "bb310bd3-f44f-4617-8195-4794e8e5851b",
"op" : "eval",
"processor" : "session",
"args" : {
"gremlin" : "social.V(x)",
"language" : "gremlin-groovy",
"aliases" : {
"g" : "social"
},
"session" : "41d2e28a-20a4-4ab0-b379-d810dede3786",
"bindings" : {
"x" : 1
}
}
}
Session Close
The following RequestMessage
is an example of a request to close a session.
{
"requestId" : "58d90945-76b1-4109-b6f8-44629752bda0",
"op" : "close",
"processor" : "session",
"args" : {
"session" : "41d2e28a-20a4-4ab0-b379-d810dede3786"
}
}
Sessionless Eval
The following RequestMessage
is an example of a simple sessionless request for a script evaluation with parameters.
{
"requestId" : "7239b3a7-0e5a-4b6f-b941-bcbc2b38bf3e",
"op" : "eval",
"processor" : "",
"args" : {
"gremlin" : "g.V(x)",
"language" : "gremlin-groovy",
"bindings" : {
"x" : 1
}
}
}
Sessionless Eval
The following RequestMessage
is an example of a sessionless request for a script evaluation with an alias that binds the TraversalSource
of "g" to "social".
{
"requestId" : "6e0fea49-2ea4-4cf9-859d-723b4b468efe",
"op" : "eval",
"processor" : "",
"args" : {
"gremlin" : "social.V(x)",
"language" : "gremlin-groovy",
"aliases" : {
"g" : "social"
},
"bindings" : {
"x" : 1
}
}
}
ResponseMessage
Authentication Challenge
When authentication is enabled, an initial request to the server will result in an authentication challenge. The typical response message will appear as follows, but handling it could be different dependending on the SASL implementation (e.g. multiple challenges maybe requested in some cases, but not in the default provided by Gremlin Server).
{
"requestId" : "41d2e28a-20a4-4ab0-b379-d810dede3786",
"status" : {
"message" : "",
"code" : 407,
"attributes" : { }
},
"result" : {
"data" : null,
"meta" : { }
}
}
Standard Result
The following ResponseMessage
is a typical example of the typical successful response Gremlin Server will return when returning results from a script.
{
"requestId" : "41d2e28a-20a4-4ab0-b379-d810dede3786",
"status" : {
"message" : "",
"code" : 200,
"attributes" : { }
},
"result" : {
"data" : [ {
"id" : 1,
"label" : "person",
"type" : "vertex",
"properties" : {
"name" : [ {
"id" : 0,
"value" : "marko"
} ],
"location" : [ {
"id" : 6,
"value" : "san diego",
"properties" : {
"startTime" : 1997,
"endTime" : 2001
}
}, {
"id" : 7,
"value" : "santa cruz",
"properties" : {
"startTime" : 2001,
"endTime" : 2004
}
}, {
"id" : 8,
"value" : "brussels",
"properties" : {
"startTime" : 2004,
"endTime" : 2005
}
}, {
"id" : 9,
"value" : "santa fe",
"properties" : {
"startTime" : 2005
}
} ]
}
} ],
"meta" : { }
}
}
Time
Duration
The following example is a Duration
of five days.
"PT120H"
Instant
"2016-10-04T12:17:19.571Z"
LocalDate
"2016-01-01"
LocalDateTime
"2016-01-01T12:30"
LocalTime
"12:30:45"
MonthDay
"--01-01"
OffsetDateTime
"2016-10-04T08:17:19.613-04:00"
OffsetTime
"08:17:19.620-04:00"
Period
The following example is a Period
of one year, six months and fifteen days.
"P1Y6M15D"
Year
The following example is of the Year
"2016".
"2016"
YearMonth
The following example is a YearMonth
of "June 2016"
"2016-06"
ZonedDateTime
"2016-10-04T08:17:19.633-04:00[America/New_York]"
ZoneOffset
The following example is a ZoneOffset
of three hours, six minutes, and nine seconds.
"+03:06:09"
Version 2.0
Version 2.0 of GraphSON was first introduced on TinkerPop 3.2.2. It was designed to be less tied to Jackson (a JVM library) and to be less lossy as it pertained to types. While the GraphSON 1.0 section focused on GraphSON without embedded types, GraphSON 2.0 will do the opposite as embedded types is the expected manner in which non-JVM languages will interact with TinkerPop.
With GraphSON 2.0, there are essentially two type formats:
-
A non-typed value which is assumed the type implied by JSON. These non-types are limited to
String
,Boolean
,Map
andCollection
. -
All other values are typed by way of a "complex object" that defines a
@typeId
and@value
. The@typeId
is composed of two parts: a namespace and a type name, in the format "namespace:typename". A namespace allows TinkerPop providers and users to categorize custom types that they may implement and avoid collision with existing TinkerPop types. By default, TinkerPop types will have the namespace "g" (or "gx" for "extended" types).
Core
Class
{
"@type" : "g:Class",
"@value" : "java.io.File"
}
Date
{
"@type" : "g:Date",
"@value" : 1475583442552
}
Double
{
"@type" : "g:Double",
"@value" : 100.0
}
Float
{
"@type" : "g:Float",
"@value" : 100.0
}
Integer
{
"@type" : "g:Int32",
"@value" : 100
}
Long
{
"@type" : "g:Int64",
"@value" : 100
}
Timestamp
{
"@type" : "g:Timestamp",
"@value" : 1475583442558
}
UUID
{
"@type" : "g:UUID",
"@value" : "41d2e28a-20a4-4ab0-b379-d810dede3786"
}
Graph Structure
Edge
{
"@type" : "g:Edge",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 13
},
"label" : "develops",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : {
"@type" : "g:Int32",
"@value" : 10
},
"outV" : {
"@type" : "g:Int32",
"@value" : 1
},
"properties" : {
"since" : {
"@type" : "g:Property",
"@value" : {
"key" : "since",
"value" : {
"@type" : "g:Int32",
"@value" : 2009
}
}
}
}
}
}
Path
{
"@type" : "g:Path",
"@value" : {
"labels" : [ [ ], [ ], [ ] ],
"objects" : [ {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 1
},
"label" : "person"
}
}, {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 10
},
"label" : "software"
}
}, {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 11
},
"label" : "software"
}
} ]
}
}
Property
{
"@type" : "g:Property",
"@value" : {
"key" : "since",
"value" : {
"@type" : "g:Int32",
"@value" : 2009
}
}
}
StarGraph
{
"id" : {
"@type" : "g:Int32",
"@value" : 1
},
"label" : "person",
"outE" : {
"uses" : [ {
"id" : {
"@type" : "g:Int32",
"@value" : 16
},
"inV" : {
"@type" : "g:Int32",
"@value" : 11
},
"properties" : {
"skill" : {
"@type" : "g:Int32",
"@value" : 5
}
}
}, {
"id" : {
"@type" : "g:Int32",
"@value" : 15
},
"inV" : {
"@type" : "g:Int32",
"@value" : 10
},
"properties" : {
"skill" : {
"@type" : "g:Int32",
"@value" : 4
}
}
} ],
"develops" : [ {
"id" : {
"@type" : "g:Int32",
"@value" : 13
},
"inV" : {
"@type" : "g:Int32",
"@value" : 10
},
"properties" : {
"since" : {
"@type" : "g:Int32",
"@value" : 2009
}
}
}, {
"id" : {
"@type" : "g:Int32",
"@value" : 14
},
"inV" : {
"@type" : "g:Int32",
"@value" : 11
},
"properties" : {
"since" : {
"@type" : "g:Int32",
"@value" : 2010
}
}
} ]
},
"properties" : {
"name" : [ {
"id" : {
"@type" : "g:Int64",
"@value" : 0
},
"value" : "marko"
} ],
"location" : [ {
"id" : {
"@type" : "g:Int64",
"@value" : 6
},
"value" : "san diego",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 1997
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2001
}
}
}, {
"id" : {
"@type" : "g:Int64",
"@value" : 7
},
"value" : "santa cruz",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2001
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2004
}
}
}, {
"id" : {
"@type" : "g:Int64",
"@value" : 8
},
"value" : "brussels",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2004
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2005
}
}
}, {
"id" : {
"@type" : "g:Int64",
"@value" : 9
},
"value" : "santa fe",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2005
}
}
} ]
}
}
TinkerGraph
TinkerGraph
has a custom serializer that is registered as part of the TinkerIoRegistry
.
{
"@type" : "tinker:graph",
"@value" : {
"vertices" : [ {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 1
},
"label" : "person",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 0
},
"value" : "marko",
"label" : "name"
}
} ],
"location" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 6
},
"value" : "san diego",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 1997
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2001
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 7
},
"value" : "santa cruz",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2001
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2004
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 8
},
"value" : "brussels",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2004
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2005
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 9
},
"value" : "santa fe",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2005
}
}
}
} ]
}
}
}, {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 7
},
"label" : "person",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 1
},
"value" : "stephen",
"label" : "name"
}
} ],
"location" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 10
},
"value" : "centreville",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 1990
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2000
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 11
},
"value" : "dulles",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2000
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2006
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 12
},
"value" : "purcellville",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2006
}
}
}
} ]
}
}
}, {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 8
},
"label" : "person",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 2
},
"value" : "matthias",
"label" : "name"
}
} ],
"location" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 13
},
"value" : "bremen",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2004
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2007
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 14
},
"value" : "baltimore",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2007
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2011
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 15
},
"value" : "oakland",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2011
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2014
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 16
},
"value" : "seattle",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2014
}
}
}
} ]
}
}
}, {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 9
},
"label" : "person",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 3
},
"value" : "daniel",
"label" : "name"
}
} ],
"location" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 17
},
"value" : "spremberg",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 1982
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2005
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 18
},
"value" : "kaiserslautern",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2005
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2009
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 19
},
"value" : "aachen",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2009
}
}
}
} ]
}
}
}, {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 10
},
"label" : "software",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 4
},
"value" : "gremlin",
"label" : "name"
}
} ]
}
}
}, {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 11
},
"label" : "software",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 5
},
"value" : "tinkergraph",
"label" : "name"
}
} ]
}
}
} ],
"edges" : [ {
"@type" : "g:Edge",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 13
},
"label" : "develops",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : {
"@type" : "g:Int32",
"@value" : 10
},
"outV" : {
"@type" : "g:Int32",
"@value" : 1
},
"properties" : {
"since" : {
"@type" : "g:Property",
"@value" : {
"key" : "since",
"value" : {
"@type" : "g:Int32",
"@value" : 2009
}
}
}
}
}
}, {
"@type" : "g:Edge",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 14
},
"label" : "develops",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : {
"@type" : "g:Int32",
"@value" : 11
},
"outV" : {
"@type" : "g:Int32",
"@value" : 1
},
"properties" : {
"since" : {
"@type" : "g:Property",
"@value" : {
"key" : "since",
"value" : {
"@type" : "g:Int32",
"@value" : 2010
}
}
}
}
}
}, {
"@type" : "g:Edge",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 15
},
"label" : "uses",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : {
"@type" : "g:Int32",
"@value" : 10
},
"outV" : {
"@type" : "g:Int32",
"@value" : 1
},
"properties" : {
"skill" : {
"@type" : "g:Property",
"@value" : {
"key" : "skill",
"value" : {
"@type" : "g:Int32",
"@value" : 4
}
}
}
}
}
}, {
"@type" : "g:Edge",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 16
},
"label" : "uses",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : {
"@type" : "g:Int32",
"@value" : 11
},
"outV" : {
"@type" : "g:Int32",
"@value" : 1
},
"properties" : {
"skill" : {
"@type" : "g:Property",
"@value" : {
"key" : "skill",
"value" : {
"@type" : "g:Int32",
"@value" : 5
}
}
}
}
}
}, {
"@type" : "g:Edge",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 17
},
"label" : "develops",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : {
"@type" : "g:Int32",
"@value" : 10
},
"outV" : {
"@type" : "g:Int32",
"@value" : 7
},
"properties" : {
"since" : {
"@type" : "g:Property",
"@value" : {
"key" : "since",
"value" : {
"@type" : "g:Int32",
"@value" : 2010
}
}
}
}
}
}, {
"@type" : "g:Edge",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 18
},
"label" : "develops",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : {
"@type" : "g:Int32",
"@value" : 11
},
"outV" : {
"@type" : "g:Int32",
"@value" : 7
},
"properties" : {
"since" : {
"@type" : "g:Property",
"@value" : {
"key" : "since",
"value" : {
"@type" : "g:Int32",
"@value" : 2011
}
}
}
}
}
}, {
"@type" : "g:Edge",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 19
},
"label" : "uses",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : {
"@type" : "g:Int32",
"@value" : 10
},
"outV" : {
"@type" : "g:Int32",
"@value" : 7
},
"properties" : {
"skill" : {
"@type" : "g:Property",
"@value" : {
"key" : "skill",
"value" : {
"@type" : "g:Int32",
"@value" : 5
}
}
}
}
}
}, {
"@type" : "g:Edge",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 20
},
"label" : "uses",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : {
"@type" : "g:Int32",
"@value" : 11
},
"outV" : {
"@type" : "g:Int32",
"@value" : 7
},
"properties" : {
"skill" : {
"@type" : "g:Property",
"@value" : {
"key" : "skill",
"value" : {
"@type" : "g:Int32",
"@value" : 4
}
}
}
}
}
}, {
"@type" : "g:Edge",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 21
},
"label" : "develops",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : {
"@type" : "g:Int32",
"@value" : 10
},
"outV" : {
"@type" : "g:Int32",
"@value" : 8
},
"properties" : {
"since" : {
"@type" : "g:Property",
"@value" : {
"key" : "since",
"value" : {
"@type" : "g:Int32",
"@value" : 2012
}
}
}
}
}
}, {
"@type" : "g:Edge",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 22
},
"label" : "uses",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : {
"@type" : "g:Int32",
"@value" : 10
},
"outV" : {
"@type" : "g:Int32",
"@value" : 8
},
"properties" : {
"skill" : {
"@type" : "g:Property",
"@value" : {
"key" : "skill",
"value" : {
"@type" : "g:Int32",
"@value" : 3
}
}
}
}
}
}, {
"@type" : "g:Edge",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 23
},
"label" : "uses",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : {
"@type" : "g:Int32",
"@value" : 11
},
"outV" : {
"@type" : "g:Int32",
"@value" : 8
},
"properties" : {
"skill" : {
"@type" : "g:Property",
"@value" : {
"key" : "skill",
"value" : {
"@type" : "g:Int32",
"@value" : 3
}
}
}
}
}
}, {
"@type" : "g:Edge",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 24
},
"label" : "uses",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : {
"@type" : "g:Int32",
"@value" : 10
},
"outV" : {
"@type" : "g:Int32",
"@value" : 9
},
"properties" : {
"skill" : {
"@type" : "g:Property",
"@value" : {
"key" : "skill",
"value" : {
"@type" : "g:Int32",
"@value" : 5
}
}
}
}
}
}, {
"@type" : "g:Edge",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 25
},
"label" : "uses",
"inVLabel" : "software",
"outVLabel" : "person",
"inV" : {
"@type" : "g:Int32",
"@value" : 11
},
"outV" : {
"@type" : "g:Int32",
"@value" : 9
},
"properties" : {
"skill" : {
"@type" : "g:Property",
"@value" : {
"key" : "skill",
"value" : {
"@type" : "g:Int32",
"@value" : 3
}
}
}
}
}
}, {
"@type" : "g:Edge",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 26
},
"label" : "traverses",
"inVLabel" : "software",
"outVLabel" : "software",
"inV" : {
"@type" : "g:Int32",
"@value" : 11
},
"outV" : {
"@type" : "g:Int32",
"@value" : 10
}
}
} ]
}
}
Tree
{
"@type" : "g:Tree",
"@value" : [ {
"key" : {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 1
},
"label" : "person",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 0
},
"value" : "marko",
"label" : "name"
}
} ],
"location" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 6
},
"value" : "san diego",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 1997
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2001
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 7
},
"value" : "santa cruz",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2001
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2004
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 8
},
"value" : "brussels",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2004
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2005
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 9
},
"value" : "santa fe",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2005
}
}
}
} ]
}
}
},
"value" : {
"@type" : "g:Tree",
"@value" : [ {
"key" : {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 10
},
"label" : "software",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 4
},
"value" : "gremlin",
"label" : "name"
}
} ]
}
}
},
"value" : {
"@type" : "g:Tree",
"@value" : [ {
"key" : {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 11
},
"label" : "software",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 5
},
"value" : "tinkergraph",
"label" : "name"
}
} ]
}
}
},
"value" : {
"@type" : "g:Tree",
"@value" : [ ]
}
} ]
}
} ]
}
}, {
"key" : {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 7
},
"label" : "person",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 1
},
"value" : "stephen",
"label" : "name"
}
} ],
"location" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 10
},
"value" : "centreville",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 1990
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2000
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 11
},
"value" : "dulles",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2000
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2006
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 12
},
"value" : "purcellville",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2006
}
}
}
} ]
}
}
},
"value" : {
"@type" : "g:Tree",
"@value" : [ {
"key" : {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 10
},
"label" : "software",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 4
},
"value" : "gremlin",
"label" : "name"
}
} ]
}
}
},
"value" : {
"@type" : "g:Tree",
"@value" : [ {
"key" : {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 11
},
"label" : "software",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 5
},
"value" : "tinkergraph",
"label" : "name"
}
} ]
}
}
},
"value" : {
"@type" : "g:Tree",
"@value" : [ ]
}
} ]
}
} ]
}
}, {
"key" : {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 8
},
"label" : "person",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 2
},
"value" : "matthias",
"label" : "name"
}
} ],
"location" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 13
},
"value" : "bremen",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2004
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2007
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 14
},
"value" : "baltimore",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2007
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2011
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 15
},
"value" : "oakland",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2011
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2014
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 16
},
"value" : "seattle",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2014
}
}
}
} ]
}
}
},
"value" : {
"@type" : "g:Tree",
"@value" : [ {
"key" : {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 10
},
"label" : "software",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 4
},
"value" : "gremlin",
"label" : "name"
}
} ]
}
}
},
"value" : {
"@type" : "g:Tree",
"@value" : [ {
"key" : {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 11
},
"label" : "software",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 5
},
"value" : "tinkergraph",
"label" : "name"
}
} ]
}
}
},
"value" : {
"@type" : "g:Tree",
"@value" : [ ]
}
} ]
}
} ]
}
}, {
"key" : {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 9
},
"label" : "person",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 3
},
"value" : "daniel",
"label" : "name"
}
} ],
"location" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 17
},
"value" : "spremberg",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 1982
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2005
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 18
},
"value" : "kaiserslautern",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2005
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2009
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 19
},
"value" : "aachen",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2009
}
}
}
} ]
}
}
},
"value" : {
"@type" : "g:Tree",
"@value" : [ {
"key" : {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 10
},
"label" : "software",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 4
},
"value" : "gremlin",
"label" : "name"
}
} ]
}
}
},
"value" : {
"@type" : "g:Tree",
"@value" : [ {
"key" : {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 11
},
"label" : "software",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 5
},
"value" : "tinkergraph",
"label" : "name"
}
} ]
}
}
},
"value" : {
"@type" : "g:Tree",
"@value" : [ ]
}
} ]
}
} ]
}
} ]
}
Vertex
{
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 1
},
"label" : "person",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 0
},
"value" : "marko",
"label" : "name"
}
} ],
"location" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 6
},
"value" : "san diego",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 1997
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2001
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 7
},
"value" : "santa cruz",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2001
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2004
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 8
},
"value" : "brussels",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2004
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2005
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 9
},
"value" : "santa fe",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2005
}
}
}
} ]
}
}
}
VertexProperty
{
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 0
},
"value" : "marko",
"label" : "name"
}
}
Graph Process
Barrier
{
"@type" : "g:Barrier",
"@value" : "normSack"
}
Binding
A "Binding" refers to a Bytecode.Binding
.
{
"@type" : "g:Binding",
"@value" : {
"key" : "x",
"value" : {
"@type" : "g:Int32",
"@value" : 1
}
}
}
Bytecode
The following Bytecode
example represents the traversal of g.V().hasLabel('person').out().in().tree()
. Obviously the serialized Bytecode
woudl be quite different for the endless variations of commands that could be used together in the Gremlin language.
{
"@type" : "g:Bytecode",
"@value" : {
"step" : [ [ "V" ], [ "has", {
"@type" : "g:T",
"@value" : "label"
}, {
"@type" : "g:P",
"@value" : {
"predicate" : "eq",
"value" : "person"
}
} ], [ "out" ], [ "in" ], [ "tree" ] ]
}
}
Cardinality
{
"@type" : "g:Cardinality",
"@value" : "list"
}
Column
{
"@type" : "g:Column",
"@value" : "keys"
}
Direction
{
"@type" : "g:Direction",
"@value" : "OUT"
}
Operator
{
"@type" : "g:Operator",
"@value" : "sum"
}
Order
{
"@type" : "g:Order",
"@value" : "incr"
}
Pop
{
"@type" : "g:Pop",
"@value" : "all"
}
Lambda
{
"@type" : "g:Lambda",
"@value" : {
"script" : "{ it.get() }",
"language" : "gremlin-groovy",
"arguments" : 1
}
}
Metrics
{
"@type" : "g:Metrics",
"@value" : {
"dur" : {
"@type" : "g:Double",
"@value" : 0.163871
},
"counts" : {
"traverserCount" : {
"@type" : "g:Int64",
"@value" : 4
},
"elementCount" : {
"@type" : "g:Int64",
"@value" : 4
}
},
"name" : "TinkerGraphStep(vertex,[~label.eq(person)])",
"annotations" : {
"percentDur" : {
"@type" : "g:Double",
"@value" : 14.805689498929809
}
},
"id" : "7.0.0()",
"metrics" : [ {
"@type" : "g:Metrics",
"@value" : {
"dur" : {
"@type" : "g:Double",
"@value" : 0.293702
},
"counts" : {
"traverserCount" : {
"@type" : "g:Int64",
"@value" : 13
},
"elementCount" : {
"@type" : "g:Int64",
"@value" : 13
}
},
"name" : "VertexStep(OUT,vertex)",
"annotations" : {
"percentDur" : {
"@type" : "g:Double",
"@value" : 26.535876495625722
}
},
"id" : "2.0.0()"
}
} ]
}
}
P
{
"@type" : "g:P",
"@value" : {
"predicate" : "gt",
"value" : {
"@type" : "g:Int32",
"@value" : 0
}
}
}
P and
{
"@type" : "g:P",
"@value" : {
"predicate" : "and",
"value" : [ {
"@type" : "g:P",
"@value" : {
"predicate" : "gt",
"value" : {
"@type" : "g:Int32",
"@value" : 0
}
}
}, {
"@type" : "g:P",
"@value" : {
"predicate" : "lt",
"value" : {
"@type" : "g:Int32",
"@value" : 10
}
}
} ]
}
}
P or
{
"@type" : "g:P",
"@value" : {
"predicate" : "or",
"value" : [ {
"@type" : "g:P",
"@value" : {
"predicate" : "gt",
"value" : {
"@type" : "g:Int32",
"@value" : 0
}
}
}, {
"@type" : "g:P",
"@value" : {
"predicate" : "within",
"value" : [ {
"@type" : "g:Int32",
"@value" : -1
}, {
"@type" : "g:Int32",
"@value" : -10
}, {
"@type" : "g:Int32",
"@value" : -100
} ]
}
} ]
}
}
Scope
{
"@type" : "g:Scope",
"@value" : "local"
}
T
{
"@type" : "g:T",
"@value" : "label"
}
TraversalMetrics
{
"@type" : "g:TraversalMetrics",
"@value" : {
"dur" : {
"@type" : "g:Double",
"@value" : 1.10424
},
"metrics" : [ {
"@type" : "g:metrics",
"@value" : {
"dur" : {
"@type" : "g:Double",
"@value" : 0.162194
},
"counts" : {
"traverserCount" : {
"@type" : "g:Int64",
"@value" : 4
},
"elementCount" : {
"@type" : "g:Int64",
"@value" : 4
}
},
"name" : "TinkerGraphStep(vertex,[~label.eq(person)])",
"annotations" : {
"percentDur" : {
"@type" : "g:Double",
"@value" : 14.688292400202855
}
},
"id" : "7.0.0()"
}
}, {
"@type" : "g:metrics",
"@value" : {
"dur" : {
"@type" : "g:Double",
"@value" : 0.304753
},
"counts" : {
"traverserCount" : {
"@type" : "g:Int64",
"@value" : 13
},
"elementCount" : {
"@type" : "g:Int64",
"@value" : 13
}
},
"name" : "VertexStep(OUT,vertex)",
"annotations" : {
"percentDur" : {
"@type" : "g:Double",
"@value" : 27.59843874520032
}
},
"id" : "2.0.0()"
}
}, {
"@type" : "g:metrics",
"@value" : {
"dur" : {
"@type" : "g:Double",
"@value" : 0.196628
},
"counts" : {
"traverserCount" : {
"@type" : "g:Int64",
"@value" : 7
},
"elementCount" : {
"@type" : "g:Int64",
"@value" : 7
}
},
"name" : "VertexStep(OUT,vertex)",
"annotations" : {
"percentDur" : {
"@type" : "g:Double",
"@value" : 17.80663623849888
}
},
"id" : "3.0.0()"
}
}, {
"@type" : "g:metrics",
"@value" : {
"dur" : {
"@type" : "g:Double",
"@value" : 0.440665
},
"counts" : {
"traverserCount" : {
"@type" : "g:Int64",
"@value" : 1
},
"elementCount" : {
"@type" : "g:Int64",
"@value" : 1
}
},
"name" : "TreeStep",
"annotations" : {
"percentDur" : {
"@type" : "g:Double",
"@value" : 39.90663261609795
}
},
"id" : "4.0.0()"
}
} ]
}
}
Traverser
{
"@type" : "g:Traverser",
"@value" : {
"bulk" : {
"@type" : "g:Int64",
"@value" : 1
},
"value" : {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 1
},
"label" : "person",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 0
},
"value" : "marko",
"label" : "name"
}
} ],
"location" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 6
},
"value" : "san diego",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 1997
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2001
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 7
},
"value" : "santa cruz",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2001
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2004
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 8
},
"value" : "brussels",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2004
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2005
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 9
},
"value" : "santa fe",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2005
}
}
}
} ]
}
}
}
}
}
RequestMessage
Authentication Response
The following RequestMessage
is an example of the response that should be made to a SASL-based authentication challenge.
{
"requestId" : {
"@type" : "g:UUID",
"@value" : "79fcec2e-62f3-4cb4-82a6-7f879bc04c42"
},
"op" : "authentication",
"processor" : "",
"args" : {
"saslMechanism" : "PLAIN",
"sasl" : "AHN0ZXBocGhlbgBwYXNzd29yZA=="
}
}
Session Eval
The following RequestMessage
is an example of a simple session request for a script evaluation with parameters.
{
"requestId" : {
"@type" : "g:UUID",
"@value" : "c4183c83-8cd5-4058-ae9d-53e74f383031"
},
"op" : "eval",
"processor" : "session",
"args" : {
"gremlin" : "g.V(x)",
"language" : "gremlin-groovy",
"session" : {
"@type" : "g:UUID",
"@value" : "41d2e28a-20a4-4ab0-b379-d810dede3786"
},
"bindings" : {
"x" : {
"@type" : "g:Int32",
"@value" : 1
}
}
}
}
Session Eval
The following RequestMessage
is an example of a session request for a script evaluation with an alias that binds the TraversalSource
of "g" to "social".
{
"requestId" : {
"@type" : "g:UUID",
"@value" : "11944916-6fbb-4746-9bf1-53e9754dbe28"
},
"op" : "eval",
"processor" : "session",
"args" : {
"gremlin" : "social.V(x)",
"language" : "gremlin-groovy",
"aliases" : {
"g" : "social"
},
"session" : {
"@type" : "g:UUID",
"@value" : "41d2e28a-20a4-4ab0-b379-d810dede3786"
},
"bindings" : {
"x" : {
"@type" : "g:Int32",
"@value" : 1
}
}
}
}
Session Close
The following RequestMessage
is an example of a request to close a session.
{
"requestId" : {
"@type" : "g:UUID",
"@value" : "4b5c19fa-3bb5-482c-bca1-ac8ae408c95b"
},
"op" : "close",
"processor" : "session",
"args" : {
"session" : {
"@type" : "g:UUID",
"@value" : "41d2e28a-20a4-4ab0-b379-d810dede3786"
}
}
}
Sessionless Eval
The following RequestMessage
is an example of a simple sessionless request for a script evaluation with parameters.
{
"requestId" : {
"@type" : "g:UUID",
"@value" : "3304b3e0-9995-4eca-b8fb-14bbef01f7b8"
},
"op" : "eval",
"processor" : "",
"args" : {
"gremlin" : "g.V(x)",
"language" : "gremlin-groovy",
"bindings" : {
"x" : {
"@type" : "g:Int32",
"@value" : 1
}
}
}
}
Sessionless Eval
The following RequestMessage
is an example of a sessionless request for a script evaluation with an alias that binds the TraversalSource
of "g" to "social".
{
"requestId" : {
"@type" : "g:UUID",
"@value" : "0b93d54e-4124-4401-8b8f-addb18a213ea"
},
"op" : "eval",
"processor" : "",
"args" : {
"gremlin" : "social.V(x)",
"language" : "gremlin-groovy",
"aliases" : {
"g" : "social"
},
"bindings" : {
"x" : {
"@type" : "g:Int32",
"@value" : 1
}
}
}
}
ResponseMessage
Authentication Challenge
When authentication is enabled, an initial request to the server will result in an authentication challenge. The typical response message will appear as follows, but handling it could be different dependending on the SASL implementation (e.g. multiple challenges maybe requested in some cases, but not in the default provided by Gremlin Server).
{
"requestId" : "41d2e28a-20a4-4ab0-b379-d810dede3786",
"status" : {
"message" : "",
"code" : 407,
"attributes" : { }
},
"result" : {
"data" : null,
"meta" : { }
}
}
Standard Result
The following ResponseMessage
is a typical example of the typical successful response Gremlin Server will return when returning results from a script.
{
"requestId" : "41d2e28a-20a4-4ab0-b379-d810dede3786",
"status" : {
"message" : "",
"code" : 200,
"attributes" : { }
},
"result" : {
"data" : [ {
"@type" : "g:Vertex",
"@value" : {
"id" : {
"@type" : "g:Int32",
"@value" : 1
},
"label" : "person",
"properties" : {
"name" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 0
},
"value" : "marko",
"label" : "name"
}
} ],
"location" : [ {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 6
},
"value" : "san diego",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 1997
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2001
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 7
},
"value" : "santa cruz",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2001
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2004
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 8
},
"value" : "brussels",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2004
},
"endTime" : {
"@type" : "g:Int32",
"@value" : 2005
}
}
}
}, {
"@type" : "g:VertexProperty",
"@value" : {
"id" : {
"@type" : "g:Int64",
"@value" : 9
},
"value" : "santa fe",
"label" : "location",
"properties" : {
"startTime" : {
"@type" : "g:Int32",
"@value" : 2005
}
}
}
} ]
}
}
} ],
"meta" : { }
}
}
Extended
Note that the "extended" types require the addition of the separate GraphSONXModuleV2d0
module as follows:
mapper = GraphSONMapper.build().
typeInfo(TypeInfo.PARTIAL_TYPES).
addCustomModule(GraphSONXModuleV2d0.build().create(false)).
version(GraphSONVersion.V2_0).create().createMapper()
BigDecimal
{
"@type" : "gx:BigDecimal",
"@value" : 123456789987654321123456789987654321
}
BigInteger
{
"@type" : "gx:BigInteger",
"@value" : 123456789987654321123456789987654321
}
Byte
{
"@type" : "gx:Byte",
"@value" : 1
}
ByteBuffer
{
"@type" : "gx:ByteBuffer",
"@value" : "AQIDBAU="
}
Char
{
"@type" : "gx:Char",
"@value" : "x"
}
Duration
The following example is a Duration
of five days.
{
"@type" : "gx:Duration",
"@value" : "PT120H"
}
InetAddress
{
"@type" : "gx:InetAddress",
"@value" : "localhost"
}
Instant
{
"@type" : "gx:Instant",
"@value" : "2016-10-04T12:17:22.696Z"
}
LocalDate
{
"@type" : "gx:LocalDate",
"@value" : "2016-01-01"
}
LocalDateTime
{
"@type" : "gx:LocalDateTime",
"@value" : "2016-01-01T12:30"
}
LocalTime
{
"@type" : "gx:LocalTime",
"@value" : "12:30:45"
}
MonthDay
{
"@type" : "gx:MonthDay",
"@value" : "--01-01"
}
OffsetDateTime
{
"@type" : "gx:OffsetDateTime",
"@value" : "2016-10-04T08:17:22.699-04:00"
}
OffsetTime
{
"@type" : "gx:OffsetTime",
"@value" : "08:17:22.701-04:00"
}
Period
The following example is a Period
of one year, six months and fifteen days.
{
"@type" : "gx:Period",
"@value" : "P1Y6M15D"
}
Short
{
"@type" : "gx:Int16",
"@value" : 100
}
Year
The following example is of the Year
"2016".
{
"@type" : "gx:Year",
"@value" : "2016"
}
YearMonth
The following example is a YearMonth
of "June 2016"
{
"@type" : "gx:YearMonth",
"@value" : "2016-06"
}
ZonedDateTime
{
"@type" : "gx:ZonedDateTime",
"@value" : "2016-10-04T08:17:22.708-04:00[America/New_York]"
}
ZoneOffset
The following example is a ZoneOffset
of three hours, six minutes, and nine seconds.
{
"@type" : "gx:ZoneOffset",
"@value" : "+03:06:09"
}
Gryo
Gryo uses the popular Kryo library to handle binary serialization for the JVM. There currently aren’t any Kryo implementations in other languages so the binding of this format to the JVM is a bit of a limitation, but if building a system on the JVM the use of Gryo over other serialization format should yield smaller data sizes than other formats like GraphSON or GraphML, improved serialization speed, as well as better support for the various Java data types that might not be supported otherwise.
Gryo is useful both as a "graph" serialization format and as a generalized serialization format that can read or write any object. This characteristic makes it ideal for use in Gremlin Server, which is designed to return arbitrary results of varying types.
It is unlikely that Gryo users will try to consume or produce Gryo without using TinkerPop and Kryo classes to help do it. Attempting to read or write a byte stream of Gryo without those tools would be challenging, so the depths of what the Gryo format looks like in a byte-by-byte perspective will not be discussed here. It is enough to know that TinkerPop has Kryo-based serializers for certain classes that it supports and that the bytes written or read must be Kryo compliant.
While there is only one version of Gryo at the moment, 1.0, the format has generally expanded as new releases of TinkerPop have been produced. "Expansion" has generally meant that new types have come to be supported over time. The addition of new types means that while Gryo has remained at 1.0, older releases that produced Gryo files will not be compatible with newer TinkerPop releases if the newer types are utilized. On the flip side, newer release of TinkerPop are fully backward compatible with Gryo produced on older versions of TinkerPop.
The full list of Gryo 1.0 types can be found in the GryoMapper
source code. Looking at the source code for a specific
release tag would show what types were compatible for a specific release. For example, the type listing for 3.2.2
can be found here.
One of the key aspects of Gryo is that, by default, it requires that all types expected to be used to be registered
with the GryoMapper
. There are two ways to do that:
-
On the
GryoMapper.Builder
, use theaddCustom
methods. These methods allow registration of single classes with an optional custom serializer. -
Add a custom
IoRegistry
implementation with theaddRegistry
method onGryoMapper.Builder
. TheIoRegistry
contains registrations that will be supplied to theGryoMapper
. There is additional documentation on how this works in the provider documentation.
When using addCustom
or addRegistry
, it is important to remember that the order in which those methods are called
is important. The registrations get numeric "registration ids" and their order must match if the the Gryo is expected
to be compatible. Calls to addCustom
will be applied first, prior to calls to addRegistry
(which internally call
addCustom
).
It is possible to disable registration by setting registrationRequired
on the GryoMapper.Builder
to false
, but
Gryo is less efficient with this feature is turned off.