ArangoDB v3.4 reached End of Life (EOL) and is no longer supported.
This documentation is outdated. Please see the most recent version here: Latest Docs
Handling Edges
Examples will explain the REST API for manipulating edges of the graph module on the knows graph:
Create an edge
Creates an edge in an existing graph
POST /_api/gharial/{graph}/edge/{collection}
Path Parameters
-
graph (required): The name of the graph.
-
collection (required): The name of the edge collection the edge belongs to.
Query Parameters
-
waitForSync (optional): Define if the request should wait until synced to disk.
-
returnNew (optional): Define if the response should contain the complete new version of the document.
A JSON object with these properties is required:
-
_from: The source vertex of this edge. Has to be valid within the used edge definition.
-
_to: The target vertex of this edge. Has to be valid within the used edge definition.
Creates a new edge in the collection. Within the body the edge has to contain a _from and _to value referencing to valid vertices in the graph. Furthermore the edge has to be valid in the definition of the used edge collection.
HTTP 201 Returned if the edge could be created and waitForSync is true.
-
error: Flag if there was an error (true) or not (false). It is false in this response.
-
code: The response code.
-
edge: The internal attributes for the edge.
-
new: The complete newly written edge document. Includes all written attributes in the request body and all internal attributes generated by ArangoDB. Will only be present if returnNew is true.
HTTP 202 Returned if the request was successful but waitForSync is false.
-
error: Flag if there was an error (true) or not (false). It is false in this response.
-
code: The response code.
-
edge: The internal attributes for the edge.
-
new: The complete newly written edge document. Includes all written attributes in the request body and all internal attributes generated by ArangoDB. Will only be present if returnNew is true.
HTTP 400 Returned if the input document is invalid.
This can for instance be the case if _from
or _to
is mising.
-
error: Flag if there was an error (true) or not (false). It is true in this response.
-
code: The response code.
-
errorNum: ArangoDB error number for the error that occured.
-
errorMessage: A message created for this error.
HTTP 403 Returned if your user has insufficient rights. In order to insert edges into the graph you at least need to have the following privileges:
Read Only
access on the Database.Write
access on the given collection.
-
error: Flag if there was an error (true) or not (false). It is true in this response.
-
code: The response code.
-
errorNum: ArangoDB error number for the error that occured.
-
errorMessage: A message created for this error.
HTTP 404 Returned in any of the following cases:
- no graph with this name could be found.
- this edge collection is not part of the graph.
-
either
_from
or_to
vertex does not exist.-
error: Flag if there was an error (true) or not (false). It is true in this response.
-
code: The response code.
-
errorNum: ArangoDB error number for the error that occured.
-
errorMessage: A message created for this error.
-
Examples
shell> curl -X POST --header 'accept: application/json' --data-binary @- --dump - http://localhost:8529/_api/gharial/social/edge/relation <<EOF
{
"type" : "friend",
"_from" : "female/alice",
"_to" : "female/diana"
}
EOF
HTTP/1.1 Accepted
content-type: application/json; charset=utf-8
etag: _bHcRDFW---
x-content-type-options: nosniff
{
"error" : false,
"code" : 202,
"edge" : {
"_id" : "relation/67159",
"_key" : "67159",
"_rev" : "_bHcRDFW---"
}
}
shell> curl -X POST --header 'accept: application/json' --data-binary @- --dump - http://localhost:8529/_api/gharial/social/edge/relation <<EOF
{
"type" : "friend",
"_from" : "female/alice",
"_to" : "female/diana"
}
EOF
HTTP/1.1 Accepted
content-type: application/json; charset=utf-8
etag: _bHcRDFW---
x-content-type-options: nosniff
Get an edge
fetch an edge
GET /_api/gharial/{graph}/edge/{collection}/{edge}
Path Parameters
-
graph (required): The name of the graph.
-
collection (required): The name of the edge collection the edge belongs to.
-
edge (required): The _key attribute of the edge.
Query Parameters
- rev (optional): Must contain a revision. If this is set a document is only returned if it has exactly this revision. Also see if-match header as an alternative to this.
Header Parameters
-
if-match (optional): If the “If-Match” header is given, then it must contain exactly one Etag. The document is returned, if it has the same revision as the given Etag. Otherwise a HTTP 412 is returned. As an alternative you can supply the Etag in an attribute rev in the URL.
-
if-none-match (optional): If the “If-None-Match” header is given, then it must contain exactly one Etag. The document is returned, only if it has a different revision as the given Etag. Otherwise a HTTP 304 is returned.
Gets an edge from the given collection.
HTTP 200 Returned if the edge could be found.
-
error: Flag if there was an error (true) or not (false). It is false in this response.
-
code: The response code.
-
edge: The complete edge.
HTTP 304 Returned if the if-none-match header is given and the currently stored edge still has this revision value. So there was no update between the last time the edge was fetched by the caller.
-
error: Flag if there was an error (true) or not (false). It is true in this response.
-
code: The response code.
-
errorNum: ArangoDB error number for the error that occured.
-
errorMessage: A message created for this error.
HTTP 403 Returned if your user has insufficient rights. In order to update vertices in the graph you at least need to have the following privileges:
Read Only
access on the Database.Read Only
access on the given collection.
-
error: Flag if there was an error (true) or not (false). It is true in this response.
-
code: The response code.
-
errorNum: ArangoDB error number for the error that occured.
-
errorMessage: A message created for this error.
HTTP 404 Returned in the following cases:
- No graph with this name could be found.
- This collection is not part of the graph.
-
The edge does not exist.
-
error: Flag if there was an error (true) or not (false). It is true in this response.
-
code: The response code.
-
errorNum: ArangoDB error number for the error that occured.
-
errorMessage: A message created for this error.
-
HTTP 412 Returned if if-match header is given, but the stored documents revision is different.
-
error: Flag if there was an error (true) or not (false). It is true in this response.
-
code: The response code.
-
errorNum: ArangoDB error number for the error that occured.
-
errorMessage: A message created for this error.
Examples
shell> curl --header 'accept: application/json' --dump - http://localhost:8529/_api/gharial/social/edge/relation/67612
HTTP/1.1 OK
content-type: application/json; charset=utf-8
etag: _bHcRDVy--A
x-content-type-options: nosniff
{
"error" : false,
"code" : 200,
"edge" : {
"_key" : "67612",
"_id" : "relation/67612",
"_from" : "female/alice",
"_to" : "male/bob",
"_rev" : "_bHcRDVy--A",
"type" : "married",
"vertex" : "alice"
}
}
shell> curl --header 'accept: application/json' --dump - http://localhost:8529/_api/gharial/social/edge/relation/67612
HTTP/1.1 OK
content-type: application/json; charset=utf-8
etag: _bHcRDVy--A
x-content-type-options: nosniff
Examples will explain the API on the social graph:
Modify an edge
modify an existing edge
PATCH /_api/gharial/{graph}/edge/{collection}/{edge}
Path Parameters
-
graph (required): The name of the graph.
-
collection (required): The name of the edge collection the edge belongs to.
-
edge (required): The _key attribute of the vertex.
Query Parameters
-
waitForSync (optional): Define if the request should wait until synced to disk.
-
keepNull (optional): Define if values set to null should be stored. By default (true) the given documents attribute(s) will be set to null. If this parameter is false the attribute(s) will instead be deleted from the document.
-
returnOld (optional): Define if a presentation of the deleted document should be returned within the response object.
-
returnNew (optional): Define if a presentation of the new document should be returned within the response object.
Header Parameters
- if-match (optional): If the “If-Match” header is given, then it must contain exactly one Etag. The document is updated, if it has the same revision as the given Etag. Otherwise a HTTP 412 is returned. As an alternative you can supply the Etag in an attribute rev in the URL.
Request Body (object)
The body has to contain a JSON object containing exactly the attributes that should be overwritten, all other attributes remain unchanged.
Updates the data of the specific edge in the collection.
HTTP 200 Returned if the edge could be updated, and waitForSync is false.
-
error: Flag if there was an error (true) or not (false). It is false in this response.
-
code: The response code.
-
edge: The internal attributes for the edge.
-
new: The complete newly written edge document. Includes all written attributes in the request body and all internal attributes generated by ArangoDB. Will only be present if returnNew is true.
-
old: The complete overwritten edge document. Includes all attributes stored before this operation. Will only be present if returnOld is true.
HTTP 202 Returned if the request was successful but waitForSync is false.
-
error: Flag if there was an error (true) or not (false). It is false in this response.
-
code: The response code.
-
edge: The internal attributes for the edge.
-
new: The complete newly written edge document. Includes all written attributes in the request body and all internal attributes generated by ArangoDB. Will only be present if returnNew is true.
-
old: The complete overwritten edge document. Includes all attributes stored before this operation. Will only be present if returnOld is true.
HTTP 403 Returned if your user has insufficient rights. In order to update edges in the graph you at least need to have the following privileges:
Read Only
access on the Database.Write
access on the given collection.
-
error: Flag if there was an error (true) or not (false). It is true in this response.
-
code: The response code.
-
errorNum: ArangoDB error number for the error that occured.
-
errorMessage: A message created for this error.
HTTP 404 Returned in the following cases:
- No graph with this name could be found.
- This collection is not part of the graph.
- The edge to update does not exist.
-
either
_from
or_to
vertex does not exist (if updated).-
error: Flag if there was an error (true) or not (false). It is true in this response.
-
code: The response code.
-
errorNum: ArangoDB error number for the error that occured.
-
errorMessage: A message created for this error.
-
HTTP 412 Returned if if-match header is given, but the stored documents revision is different.
-
error: Flag if there was an error (true) or not (false). It is true in this response.
-
code: The response code.
-
errorNum: ArangoDB error number for the error that occured.
-
errorMessage: A message created for this error.
Examples
shell> curl -X PATCH --header 'accept: application/json' --data-binary @- --dump - http://localhost:8529/_api/gharial/social/edge/relation/67992 <<EOF
{
"since" : "01.01.2001"
}
EOF
HTTP/1.1 Accepted
content-type: application/json; charset=utf-8
etag: _bHcRDkq--_
x-content-type-options: nosniff
{
"error" : false,
"code" : 202,
"edge" : {
"_id" : "relation/67992",
"_key" : "67992",
"_oldRev" : "_bHcRDke---",
"_rev" : "_bHcRDkq--_"
}
}
shell> curl -X PATCH --header 'accept: application/json' --data-binary @- --dump - http://localhost:8529/_api/gharial/social/edge/relation/67992 <<EOF
{
"since" : "01.01.2001"
}
EOF
HTTP/1.1 Accepted
content-type: application/json; charset=utf-8
etag: _bHcRDkq--_
x-content-type-options: nosniff
Replace an edge
replace the content of an existing edge
PUT /_api/gharial/{graph}/edge/{collection}/{edge}
Path Parameters
-
graph (required): The name of the graph.
-
collection (required): The name of the edge collection the edge belongs to.
-
edge (required): The _key attribute of the vertex.
Query Parameters
-
waitForSync (optional): Define if the request should wait until synced to disk.
-
keepNull (optional): Define if values set to null should be stored. By default the key is not removed from the document.
-
returnOld (optional): Define if a presentation of the deleted document should be returned within the response object.
-
returnNew (optional): Define if a presentation of the new document should be returned within the response object.
Header Parameters
- if-match (optional): If the “If-Match” header is given, then it must contain exactly one Etag. The document is updated, if it has the same revision as the given Etag. Otherwise a HTTP 412 is returned. As an alternative you can supply the Etag in an attribute rev in the URL.
A JSON object with these properties is required:
-
_from: The source vertex of this edge. Has to be valid within the used edge definition.
-
_to: The target vertex of this edge. Has to be valid within the used edge definition.
Replaces the data of an edge in the collection.
HTTP 201 Returned if the request was successful but waitForSync is true.
-
error: Flag if there was an error (true) or not (false). It is false in this response.
-
code: The response code.
-
edge: The internal attributes for the edge
-
new: The complete newly written edge document. Includes all written attributes in the request body and all internal attributes generated by ArangoDB. Will only be present if returnNew is true.
-
old: The complete overwritten edge document. Includes all attributes stored before this operation. Will only be present if returnOld is true.
HTTP 202 Returned if the request was successful but waitForSync is false.
-
error: Flag if there was an error (true) or not (false). It is false in this response.
-
code: The response code.
-
edge: The internal attributes for the edge
-
new: The complete newly written edge document. Includes all written attributes in the request body and all internal attributes generated by ArangoDB. Will only be present if returnNew is true.
-
old: The complete overwritten edge document. Includes all attributes stored before this operation. Will only be present if returnOld is true.
HTTP 403 Returned if your user has insufficient rights. In order to replace edges in the graph you at least need to have the following privileges:
Read Only
access on the Database.Write
access on the given collection.
-
error: Flag if there was an error (true) or not (false). It is true in this response.
-
code: The response code.
-
errorNum: ArangoDB error number for the error that occured.
-
errorMessage: A message created for this error.
HTTP 404 Returned in the following cases:
- No graph with this name could be found.
- This collection is not part of the graph.
- The edge to replace does not exist.
-
either
_from
or_to
vertex does not exist.-
error: Flag if there was an error (true) or not (false). It is true in this response.
-
code: The response code.
-
errorNum: ArangoDB error number for the error that occured.
-
errorMessage: A message created for this error.
-
HTTP 412 Returned if if-match header is given, but the stored documents revision is different.
-
error: Flag if there was an error (true) or not (false). It is true in this response.
-
code: The response code.
-
errorNum: ArangoDB error number for the error that occured.
-
errorMessage: A message created for this error.
Examples
shell> curl -X PUT --header 'accept: application/json' --data-binary @- --dump - http://localhost:8529/_api/gharial/social/edge/relation/68042 <<EOF
{
"type" : "divorced",
"_from" : "female/alice",
"_to" : "male/bob"
}
EOF
HTTP/1.1 Accepted
content-type: application/json; charset=utf-8
etag: _bHcRDma--_
x-content-type-options: nosniff
{
"error" : false,
"code" : 202,
"edge" : {
"_id" : "relation/68042",
"_key" : "68042",
"_oldRev" : "_bHcRDmS---",
"_rev" : "_bHcRDma--_"
}
}
shell> curl -X PUT --header 'accept: application/json' --data-binary @- --dump - http://localhost:8529/_api/gharial/social/edge/relation/68042 <<EOF
{
"type" : "divorced",
"_from" : "female/alice",
"_to" : "male/bob"
}
EOF
HTTP/1.1 Accepted
content-type: application/json; charset=utf-8
etag: _bHcRDma--_
x-content-type-options: nosniff
Remove an edge
removes an edge from graph
DELETE /_api/gharial/{graph}/edge/{collection}/{edge}
Path Parameters
-
graph (required): The name of the graph.
-
collection (required): The name of the edge collection the edge belongs to.
-
edge (required): The _key attribute of the edge.
Query Parameters
-
waitForSync (optional): Define if the request should wait until synced to disk.
-
returnOld (optional): Define if a presentation of the deleted document should be returned within the response object.
Header Parameters
- if-match (optional): If the “If-Match” header is given, then it must contain exactly one Etag. The document is updated, if it has the same revision as the given Etag. Otherwise a HTTP 412 is returned. As an alternative you can supply the Etag in an attribute rev in the URL.
Removes an edge from the collection.
HTTP 200 Returned if the edge could be removed.
-
error: Flag if there was an error (true) or not (false). It is false in this response.
-
code: The response code.
-
removed: Is set to true if the remove was successful.
-
old: The complete deleted edge document. Includes all attributes stored before this operation. Will only be present if returnOld is true.
HTTP 202 Returned if the request was successful but waitForSync is false.
-
error: Flag if there was an error (true) or not (false). It is false in this response.
-
code: The response code.
-
removed: Is set to true if the remove was successful.
-
old: The complete deleted edge document. Includes all attributes stored before this operation. Will only be present if returnOld is true.
HTTP 403 Returned if your user has insufficient rights. In order to delete vertices in the graph you at least need to have the following privileges:
Read Only
access on the Database.Write
access on the given collection.
-
error: Flag if there was an error (true) or not (false). It is true in this response.
-
code: The response code.
-
errorNum: ArangoDB error number for the error that occured.
-
errorMessage: A message created for this error.
HTTP 404 Returned in the following cases:
- No graph with this name could be found.
- This collection is not part of the graph.
-
The edge to remove does not exist.
-
error: Flag if there was an error (true) or not (false). It is true in this response.
-
code: The response code.
-
errorNum: ArangoDB error number for the error that occured.
-
errorMessage: A message created for this error.
-
HTTP 412 Returned if if-match header is given, but the stored documents revision is different.
-
error: Flag if there was an error (true) or not (false). It is true in this response.
-
code: The response code.
-
errorNum: ArangoDB error number for the error that occured.
-
errorMessage: A message created for this error.
Examples
shell> curl -X DELETE --header 'accept: application/json' --dump - http://localhost:8529/_api/gharial/social/edge/relation/67427
HTTP/1.1 Accepted
content-type: application/json; charset=utf-8
x-content-type-options: nosniff
{
"error" : false,
"code" : 202,
"removed" : true
}
shell> curl -X DELETE --header 'accept: application/json' --dump - http://localhost:8529/_api/gharial/social/edge/relation/67427
HTTP/1.1 Accepted
content-type: application/json; charset=utf-8
x-content-type-options: nosniff