use crate::query::match_all_query::MatchAllQuery;
use crate::query::multi_match_query::MultiMatchQuery;
use crate::query::QueryTrait;
use crate::util::UtilMap;
use serde_json::{json, Value};
#[derive(Default)]
pub struct ScriptScoreQuery {
query: Value,
script: String,
min_score: Option<f64>,
boost: Option<f64>,
}
impl ScriptScoreQuery {
pub fn new(script: &str) -> ScriptScoreQuery {
let mut query = ScriptScoreQuery::default();
query.script = script.to_string();
let q = MatchAllQuery::new().build();
query.query = q;
return query;
}
pub fn set_boost(mut self, boost: f64) -> ScriptScoreQuery {
self.boost = Some(boost);
self
}
}
impl QueryTrait for ScriptScoreQuery {
fn build(&self) -> Value {
let mut root = UtilMap::new();
root.append_value("query", self.query.clone());
let mut script = UtilMap::new();
script.append_string("source", self.script.clone());
root.append_object("script", script);
root.append_boost(self.boost);
root.build_object(self.query_name())
}
fn query_name(&self) -> String {
return "script_score".to_string();
}
}
#[test]
fn test() {
let q = ScriptScoreQuery::new("doc['keywords'].length == 2")
.build()
.to_string();
assert_eq!(q, "{\"script_score\":{\"query\":{\"match_all\":{}},\"script\":{\"source\":\"doc['keywords'].length == 2\"}}}")
}