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
85
86
87
88
89
use crate::types::*;
use redis::{cmd, ConnectionLike, FromRedisValue, RedisResult, ToRedisArgs};
pub trait GraphCommands: ConnectionLike + Sized {
fn graph_query<K: ToRedisArgs, Q: ToRedisArgs>(
&mut self,
key: K,
query: Q,
) -> RedisResult<GraphResultSet> {
cmd("GRAPH.QUERY").arg(key).arg(query).query(self)
}
fn graph_ro_query<K: ToRedisArgs, Q: ToRedisArgs>(
&mut self,
key: K,
query: Q,
) -> RedisResult<GraphResultSet> {
cmd("GRAPH.RO_QUERY").arg(key).arg(query).query(self)
}
fn graph_profile<K: ToRedisArgs, Q: ToRedisArgs, RV: FromRedisValue>(
&mut self,
key: K,
query: Q,
) -> RedisResult<RV> {
cmd("GRAPH.PROFILE").arg(key).arg(query).query(self)
}
fn graph_delete<K: ToRedisArgs>(&mut self, key: K) -> RedisResult<String> {
cmd("GRAPH.DELETE").arg(key).query(self)
}
fn graph_explain<K: ToRedisArgs, Q: ToRedisArgs, RV: FromRedisValue>(
&mut self,
key: K,
query: Q,
) -> RedisResult<RV> {
cmd("GRAPH.EXPLAIN").arg(key).arg(query).query(self)
}
fn graph_slowlog<K: ToRedisArgs>(&mut self, key: K) -> RedisResult<Vec<SlowLogEntry>> {
cmd("GRAPH.SLOWLOG").arg(key).query(self)
}
fn graph_config_set<K: ToRedisArgs, V: ToRedisArgs>(
&mut self,
name: K,
value: V,
) -> RedisResult<bool> {
cmd("GRAPH.CONFIG")
.arg("SET")
.arg(name)
.arg(value)
.query(self)
}
fn graph_config_get<K: ToRedisArgs, RV: FromRedisValue>(&mut self, name: K) -> RedisResult<RV> {
value_from_pair(&cmd("GRAPH.CONFIG").arg("GET").arg(name).query(self)?)
}
fn graph_config_get_all(&mut self) -> RedisResult<GraphConfig> {
cmd("GRAPH.CONFIG").arg("GET").arg("*").query(self)
}
}
impl<T> GraphCommands for T where T: ConnectionLike {}