forked from carlos-verdes/zio-arangodb
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathArangoGraph.scala
84 lines (70 loc) · 2.84 KB
/
ArangoGraph.scala
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/*
* Copyright 2022 Carlos Verdes
*
* SPDX-License-Identifier: MIT
*/
package io.funkode.arangodb
import io.funkode.velocypack.*
import model.*
import protocol.*
import ArangoMessage.*
import VPack.*
class ArangoGraph[Encoder[_], Decoder[_]](database: DatabaseName, graphName: GraphName)(using
arangoClient: ArangoClient[Encoder, Decoder]
):
def name: GraphName = graphName
private val path = ApiGharialPath.addPart(graphName.unwrap)
private val vertexPath = path.addPart("vertex")
def create(
edgeDefinitions: List[GraphEdgeDefinition] = List.empty,
orphanCollections: List[String] = List.empty,
waitForSync: Boolean = false
)(using Encoder[GraphCreate], Decoder[GraphInfo.Response]): AIO[GraphInfo] =
POST(
database,
ApiGharialPath,
Map(
"waitForSync" -> waitForSync.toString
)
).withBody(
GraphCreate(name, edgeDefinitions, orphanCollections)
).execute[GraphInfo.Response, Encoder, Decoder]
.map(_.graph)
def info(using Decoder[ArangoResult[GraphInfo.Response]]): AIO[GraphInfo] =
GET(database, path)
.executeIgnoreResult[GraphInfo.Response, Encoder, Decoder]
.map(_.graph)
def drop(dropCollections: Boolean = false)(using
Decoder[ArangoResult[RemovedResult]]
): AIO[Boolean] =
DELETE(database, path, Map("dropCollections" -> dropCollections.toString))
.executeIgnoreResult[RemovedResult, Encoder, Decoder]
.map(_.removed)
def vertexCollections(using Decoder[ArangoResponse[GraphCollections]]): AIO[List[CollectionName]] =
GET(database, vertexPath)
.execute[ArangoResponse[GraphCollections], Encoder, Decoder]
.map(_.result.collections)
def addVertexCollection(
collection: CollectionName
)(using Encoder[VertexCollectionCreate], Decoder[ArangoResponse[GraphInfo.Response]]): AIO[GraphInfo] =
POST(database, vertexPath)
.withBody(VertexCollectionCreate(collection))
.execute[ArangoResponse[GraphInfo.Response], Encoder, Decoder]
.map(_.result.graph)
def removeVertexCollection(
collection: CollectionName,
dropCollection: Boolean = false
)(using Decoder[ArangoResponse[GraphInfo.Response]]): AIO[GraphInfo] =
DELETE(
database,
vertexPath.addPart(collection.unwrap),
Map(
"dropCollection" -> dropCollection.toString
)
).execute[ArangoResponse[GraphInfo.Response], Encoder, Decoder].map(_.result.graph)
def collection(collection: CollectionName): ArangoGraphCollection[Encoder, Decoder] =
new ArangoGraphCollection[Encoder, Decoder](database, name, collection)
def vertex(handle: DocumentHandle): ArangoGraphVertex[Encoder, Decoder] =
new ArangoGraphVertex[Encoder, Decoder](database, name, handle)
def edge(handle: DocumentHandle): ArangoGraphEdge[Encoder, Decoder] =
new ArangoGraphEdge[Encoder, Decoder](database, name, handle)