use serde::Serialize;
use crate::json::ShouldSkip;
use super::{Query, ScoreMode};
#[derive(Debug, Default, Serialize)]
pub struct NestedQuery {
path: String,
#[serde(skip_serializing_if = "ShouldSkip::should_skip")]
score_mode: Option<ScoreMode>,
query: Query,
}
impl Query {
pub fn build_nested<A, B>(path: A, query: B) -> NestedQuery
where
A: Into<String>,
B: Into<Query>,
{
NestedQuery {
path: path.into(),
query: query.into(),
..Default::default()
}
}
}
impl NestedQuery {
add_field!(with_score_mode, score_mode, ScoreMode);
build!(Nested);
}
#[derive(Debug, Default, Serialize)]
pub struct HasChildQuery {
doc_type: String,
query: Query,
#[serde(skip_serializing_if = "ShouldSkip::should_skip")]
score_mode: Option<ScoreMode>,
#[serde(skip_serializing_if = "ShouldSkip::should_skip")]
min_children: Option<u64>,
#[serde(skip_serializing_if = "ShouldSkip::should_skip")]
max_children: Option<u64>,
}
#[derive(Debug, Default, Serialize)]
pub struct HasParentQuery {
parent_type: String,
query: Query,
#[serde(skip_serializing_if = "ShouldSkip::should_skip")]
score_mode: Option<ScoreMode>,
}
impl Query {
pub fn build_has_child<A, B>(doc_type: A, query: B) -> HasChildQuery
where
A: Into<String>,
B: Into<Query>,
{
HasChildQuery {
doc_type: doc_type.into(),
query: query.into(),
..Default::default()
}
}
pub fn build_has_parent<A, B>(parent_type: A, query: B) -> HasParentQuery
where
A: Into<String>,
B: Into<Query>,
{
HasParentQuery {
parent_type: parent_type.into(),
query: query.into(),
..Default::default()
}
}
}
impl HasChildQuery {
add_field!(with_score_mode, score_mode, ScoreMode);
add_field!(with_min_children, min_children, u64);
add_field!(with_max_children, max_children, u64);
build!(HasChild);
}
impl HasParentQuery {
add_field!(with_score_mode, score_mode, ScoreMode);
build!(HasParent);
}