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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
/*
* opensearch-client
*
* Rust Client for OpenSearch
*
* The version of the OpenAPI document: 3.1.0
* Contact: alberto.paro@gmail.com
* Generated by Paro OpenAPI Generator
*/
use crate::core;
use crate::common;
use serde::{Deserialize, Serialize};
/// SearchWithIndexRequestBodyJson
/// The search definition using the Query DSL
#[derive(Clone, Default, Debug, Serialize, Deserialize)]
pub struct SearchWithIndexRequestBodyJson {
#[serde(rename = "suggest", default, skip_serializing_if = "Option::is_none")]
pub suggest: Option<core::search::Suggester>,
#[serde(rename = "collapse", default, skip_serializing_if = "Option::is_none")]
pub collapse: Option<core::search::FieldCollapse>, /// Configuration of search extensions defined by OpenSearch plugins.
#[serde(rename = "ext", default, skip_serializing_if = "Option::is_none")]
pub ext: Option<serde_json::Value>, /// Set to `true` to return detailed timing information about the execution of individual components in a search request.
/// NOTE: This is a debugging tool and adds significant overhead to search execution.
#[serde(rename = "profile", default, skip_serializing_if = "Option::is_none")]
pub profile: Option<bool>, /// If `true`, returns document version as part of a hit.
#[serde(rename = "version", default, skip_serializing_if = "Option::is_none")]
pub version: Option<bool>,
#[serde(rename = "rank", default, skip_serializing_if = "Option::is_none")]
pub rank: Option<common::RankContainer>, /// If `true`, returns detailed information about score computation as part of a hit.
#[serde(rename = "explain", default, skip_serializing_if = "Option::is_none")]
pub explain: Option<bool>,
#[serde(rename = "highlight", default, skip_serializing_if = "Option::is_none")]
pub highlight: Option<String>, /// Minimum `_score` for matching documents.
/// Documents with a lower `_score` are not included in the search results.
#[serde(rename = "min_score", default, skip_serializing_if = "Option::is_none")]
pub min_score: Option<f64>, /// Maximum number of documents to collect for each shard.
/// If a query reaches this limit, OpenSearch terminates the query early.
/// OpenSearch collects documents before sorting.
/// Use with caution.
/// OpenSearch applies this parameter to each shard handling the request.
/// When possible, let OpenSearch perform early termination automatically.
/// Avoid specifying this parameter for requests that target data streams with backing indexes across multiple data tiers.
/// If set to `0` (default), the query does not terminate early.
#[serde(rename = "terminate_after", default, skip_serializing_if = "Option::is_none")]
pub terminate_after: Option<u32>,
#[serde(rename = "pit", default, skip_serializing_if = "Option::is_none")]
pub pit: Option<core::search::PointInTimeReference>, /// The number of hits to return.
/// By default, you cannot page through more than 10,000 hits using the `from` and `size` parameters.
/// To page through more hits, use the `search_after` parameter.
#[serde(rename = "size", default, skip_serializing_if = "Option::is_none")]
pub size: Option<u32>, /// The number of hits matching the query. When `true`, the exact
/// number of hits is returned at the cost of some performance. When `false`, the
/// response does not include the total number of hits matching the query.
/// Default is `10,000` hits.
#[serde(rename = "track_total_hits", default, skip_serializing_if = "Option::is_none")]
pub track_total_hits: Option<bool>, /// If `true`, calculate and return document scores, even if the scores are not used for sorting.
#[serde(rename = "track_scores", default, skip_serializing_if = "Option::is_none")]
pub track_scores: Option<bool>, /// Array of wildcard (`*`) patterns.
/// The request returns doc values for field names matching these patterns in the `hits.fields` property of the response.
#[serde(rename = "docvalue_fields", default, skip_serializing_if = "Option::is_none")]
pub docvalue_fields: Option<Vec<common::query_dsl::FieldAndFormat>>,
#[serde(rename = "stored_fields", default, skip_serializing_if = "Option::is_none")]
pub stored_fields: Option<common::Fields>,
#[serde(rename = "sort", default, skip_serializing_if = "Option::is_none")]
pub sort: Option<common::Sort>, /// Boosts the `_score` of documents from specified indexes.
#[serde(rename = "indices_boost", default, skip_serializing_if = "Option::is_none")]
pub indices_boost: Option<Vec<serde_json::Value>>, /// Defines the aggregations that are run as part of the search request.
#[serde(rename = "aggregations", default, skip_serializing_if = "Option::is_none")]
pub aggregations: Option<serde_json::Value>, /// Stats groups to associate with the search.
/// Each group maintains a statistics aggregation for its associated searches.
/// You can retrieve these stats using the indexes stats API.
#[serde(rename = "stats", default, skip_serializing_if = "Option::is_none")]
pub stats: Option<Vec<String>>,
#[serde(rename = "post_filter", default, skip_serializing_if = "Option::is_none")]
pub post_filter: Option<crate::dsl::Query>,
#[serde(rename = "slice", default, skip_serializing_if = "Option::is_none")]
pub slice: Option<common::SlicedScroll>, /// Specifies the period of time to wait for a response from each shard.
/// If no response is received before the timeout expires, the request fails and returns an error.
/// Defaults to no timeout.
#[serde(rename = "timeout", default, skip_serializing_if = "Option::is_none")]
pub timeout: Option<String>, /// Defines how to fetch a source. Fetching can be disabled entirely, or the source can be filtered.
#[serde(rename = "_source", default, skip_serializing_if = "Option::is_none")]
pub source: Option<core::search::SourceConfig>, /// Array of wildcard (`*`) patterns.
/// The request returns values for field names matching these patterns in the `hits.fields` property of the response.
#[serde(rename = "fields", default, skip_serializing_if = "Option::is_none")]
pub fields: Option<Vec<common::query_dsl::FieldAndFormat>>, /// Defines the aggregations that are run as part of the search request.
#[serde(rename = "aggs", default, skip_serializing_if = "Option::is_none")]
pub aggs: Option<serde_json::Value>,
#[serde(rename = "query", default, skip_serializing_if = "Option::is_none")]
pub query: Option<crate::dsl::Query>, /// If `true`, returns sequence number and primary term of the last modification of each hit.
#[serde(rename = "seq_no_primary_term", default, skip_serializing_if = "Option::is_none")]
pub seq_no_primary_term: Option<bool>, /// Starting document offset.
/// Needs to be non-negative.
/// By default, you cannot page through more than 10,000 hits using the `from` and `size` parameters.
/// To page through more hits, use the `search_after` parameter.
#[serde(rename = "from", default, skip_serializing_if = "Option::is_none")]
pub from: Option<u32>, /// Retrieve a script evaluation (based on different fields) for each hit.
#[serde(rename = "script_fields", default, skip_serializing_if = "Option::is_none")]
pub script_fields: Option<serde_json::Value>,
}
impl SearchWithIndexRequestBodyJson {
/// The search definition using the Query DSL
pub fn new() -> SearchWithIndexRequestBodyJson {
SearchWithIndexRequestBodyJson {
suggest: None,
collapse: None,
ext: None,
profile: None,
version: None,
rank: None,
explain: None,
highlight: None,
min_score: None,
terminate_after: None,
pit: None,
size: None,
track_total_hits: None,
track_scores: None,
docvalue_fields: None,
stored_fields: None,
sort: None,
indices_boost: None,
aggregations: None,
stats: None,
post_filter: None,
slice: None,
timeout: None,
source: None,
fields: None,
aggs: None,
query: None,
seq_no_primary_term: None,
from: None,
script_fields: None,
}
}
}