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
use crate::query::QueryTrait;
use serde::ser::SerializeStruct;
use serde::{Serialize, Serializer};
use serde_json::{json, Value};
#[derive(Default)]
pub struct RangeQuery {
field: String,
lt: String,
gt: String,
lte: String,
gte: String,
}
impl RangeQuery {
pub fn new(field: &str) -> RangeQuery {
let mut v = RangeQuery::default();
v.field = field.to_string();
return v;
}
pub fn gt(mut self, value: String) -> RangeQuery {
self.gt = value;
return self;
}
pub fn lt(mut self, value: String) -> RangeQuery {
self.lt = value;
return self;
}
pub fn gte(mut self, value: String) -> RangeQuery {
self.gte = value;
return self;
}
pub fn lte(mut self, value: String) -> RangeQuery {
self.lte = value;
return self;
}
}
impl Serialize for RangeQuery {
fn serialize<S>(&self, serializer: S) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>
where
S: Serializer,
{
let mut state = serializer.serialize_struct("RangeQuery", 0)?;
if !self.gt.is_empty() {
let _ = state.serialize_field("gt", &self.gt);
}
if !self.lt.is_empty() {
let _ = state.serialize_field("lt", &self.lt);
}
if !self.gte.is_empty() {
let _ = state.serialize_field("gte", &self.gte);
}
if !self.lte.is_empty() {
let _ = state.serialize_field("lte", &self.lte);
}
state.end()
}
}
impl QueryTrait for RangeQuery {
fn build(&self) -> Value {
let name = self.query_name();
let field = self.field.to_string();
json!({
name: {
field:self
}
})
}
fn query_name(&self) -> String {
return "range".to_string();
}
}