use serde::Serialize;
use crate::{search::*, util::*};
#[derive(Debug, Clone, PartialEq, Deserialize, Serialize)]
#[serde(remote = "Self")]
pub struct WildcardQuery {
#[serde(skip_serializing)]
field: String,
value: Option<Term>,
#[serde(default, skip_serializing_if = "ShouldSkip::should_skip")]
rewrite: Option<Rewrite>,
#[serde(default, skip_serializing_if = "ShouldSkip::should_skip")]
case_insensitive: Option<bool>,
#[serde(default, skip_serializing_if = "ShouldSkip::should_skip")]
boost: Option<f32>,
#[serde(default, skip_serializing_if = "ShouldSkip::should_skip")]
_name: Option<String>,
}
impl Query {
pub fn wildcard<T, U>(field: T, value: U) -> WildcardQuery
where
T: ToString,
U: Serialize,
{
WildcardQuery {
field: field.to_string(),
value: Term::new(value),
rewrite: None,
case_insensitive: None,
boost: None,
_name: None,
}
}
}
impl WildcardQuery {
add_boost_and_name!();
pub fn rewrite(mut self, rewrite: Rewrite) -> Self {
self.rewrite = Some(rewrite);
self
}
pub fn case_insensitive(mut self, case_insensitive: bool) -> Self {
self.case_insensitive = Some(case_insensitive);
self
}
}
impl ShouldSkip for WildcardQuery {
fn should_skip(&self) -> bool {
self.value.should_skip()
}
}
serialize_with_root_keyed!("wildcard": WildcardQuery);
deserialize_with_root_keyed!("wildcard": WildcardQuery);
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn serialization() {
assert_serialize_query(
Query::wildcard("test", "value*"),
json!({
"wildcard": {
"test": {
"value": "value*"
}
}
}),
);
assert_serialize_query(
Query::wildcard("test", "value*")
.rewrite(Rewrite::ConstantScore)
.case_insensitive(true)
.boost(2)
.name("test"),
json!({
"wildcard": {
"test": {
"value": "value*",
"rewrite": "constant_score",
"case_insensitive": true,
"boost": 2.0,
"_name": "test"
}
}
}),
);
assert_serialize_query(
Query::bool().filter(Query::wildcard("test", None::<String>)),
json!({ "bool": {} }),
)
}
}