various fixes after a review
This commit is contained in:
parent
e73052bce2
commit
eed6ab7b82
|
@ -64,7 +64,10 @@ import java.util.Objects;
|
||||||
*
|
*
|
||||||
* @see org.elasticsearch.action.search.SearchRequest#source(NewSearchSourceBuilder)
|
* @see org.elasticsearch.action.search.SearchRequest#source(NewSearchSourceBuilder)
|
||||||
*/
|
*/
|
||||||
public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeable<NewSearchSourceBuilder> {
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public final class NewSearchSourceBuilder extends ToXContentToBytes implements Writeable<NewSearchSourceBuilder> {
|
||||||
|
|
||||||
public static final ParseField FROM_FIELD = new ParseField("from");
|
public static final ParseField FROM_FIELD = new ParseField("from");
|
||||||
public static final ParseField SIZE_FIELD = new ParseField("size");
|
public static final ParseField SIZE_FIELD = new ParseField("size");
|
||||||
|
@ -97,13 +100,6 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return new NewSearchSourceBuilder();
|
return new NewSearchSourceBuilder();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* A static factory method to construct new search highlights.
|
|
||||||
*/
|
|
||||||
public static HighlightBuilder highlight() {
|
|
||||||
return new HighlightBuilder();
|
|
||||||
}
|
|
||||||
|
|
||||||
private QueryBuilder<?> queryBuilder;
|
private QueryBuilder<?> queryBuilder;
|
||||||
|
|
||||||
private QueryBuilder<?> postQueryBuilder;
|
private QueryBuilder<?> postQueryBuilder;
|
||||||
|
@ -152,7 +148,7 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructs a new search source builder with a search query.
|
* Sets the search query for this request.
|
||||||
*
|
*
|
||||||
* @see org.elasticsearch.index.query.QueryBuilders
|
* @see org.elasticsearch.index.query.QueryBuilders
|
||||||
*/
|
*/
|
||||||
|
@ -161,6 +157,13 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the query for this request
|
||||||
|
*/
|
||||||
|
public QueryBuilder<?> query() {
|
||||||
|
return queryBuilder;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets a filter that will be executed after the query has been executed and
|
* Sets a filter that will be executed after the query has been executed and
|
||||||
* only has affect on the search hits (not aggregations). This filter is
|
* only has affect on the search hits (not aggregations). This filter is
|
||||||
|
@ -171,6 +174,13 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the post filter for this request
|
||||||
|
*/
|
||||||
|
public QueryBuilder<?> postFilter() {
|
||||||
|
return postQueryBuilder;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* From index to start the search from. Defaults to <tt>0</tt>.
|
* From index to start the search from. Defaults to <tt>0</tt>.
|
||||||
*/
|
*/
|
||||||
|
@ -179,6 +189,13 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the from index to start the search from.
|
||||||
|
**/
|
||||||
|
public int from() {
|
||||||
|
return from;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The number of search hits to return. Defaults to <tt>10</tt>.
|
* The number of search hits to return. Defaults to <tt>10</tt>.
|
||||||
*/
|
*/
|
||||||
|
@ -187,6 +204,13 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the number of search hits to return.
|
||||||
|
*/
|
||||||
|
public int size() {
|
||||||
|
return size;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the minimum score below which docs will be filtered out.
|
* Sets the minimum score below which docs will be filtered out.
|
||||||
*/
|
*/
|
||||||
|
@ -195,6 +219,13 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the minimum score below which docs will be filtered out.
|
||||||
|
*/
|
||||||
|
public float minScore() {
|
||||||
|
return minScore;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Should each {@link org.elasticsearch.search.SearchHit} be returned with
|
* Should each {@link org.elasticsearch.search.SearchHit} be returned with
|
||||||
* an explanation of the hit (ranking).
|
* an explanation of the hit (ranking).
|
||||||
|
@ -204,6 +235,14 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether each search hit will be returned with an explanation of
|
||||||
|
* the hit (ranking)
|
||||||
|
*/
|
||||||
|
public Boolean explain() {
|
||||||
|
return explain;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Should each {@link org.elasticsearch.search.SearchHit} be returned with a
|
* Should each {@link org.elasticsearch.search.SearchHit} be returned with a
|
||||||
* version associated with it.
|
* version associated with it.
|
||||||
|
@ -213,6 +252,14 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether the document's version will be included in the search
|
||||||
|
* hits.
|
||||||
|
*/
|
||||||
|
public Boolean version() {
|
||||||
|
return version;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An optional timeout to control how long search is allowed to take.
|
* An optional timeout to control how long search is allowed to take.
|
||||||
*/
|
*/
|
||||||
|
@ -222,11 +269,10 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An optional timeout to control how long search is allowed to take.
|
* Gets the timeout to control how long search is allowed to take.
|
||||||
*/
|
*/
|
||||||
public NewSearchSourceBuilder timeout(String timeout) {
|
public long timeoutInMillis() {
|
||||||
this.timeoutInMillis = TimeValue.parseTimeValue(timeout, null, getClass().getSimpleName() + ".timeout").millis();
|
return timeoutInMillis;
|
||||||
return this;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -241,6 +287,13 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the number of documents to terminate after collecting.
|
||||||
|
*/
|
||||||
|
public int terminateAfter() {
|
||||||
|
return terminateAfter;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adds a sort against the given field name and the sort ordering.
|
* Adds a sort against the given field name and the sort ordering.
|
||||||
*
|
*
|
||||||
|
@ -278,6 +331,13 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the bytes representing the sort builders for this request.
|
||||||
|
*/
|
||||||
|
public List<BytesReference> sorts() {
|
||||||
|
return sorts;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Applies when sorting, and controls if scores will be tracked as well.
|
* Applies when sorting, and controls if scores will be tracked as well.
|
||||||
* Defaults to <tt>false</tt>.
|
* Defaults to <tt>false</tt>.
|
||||||
|
@ -288,7 +348,14 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add an get to perform as part of the search.
|
* Indicates whether scores will be tracked for this request.
|
||||||
|
*/
|
||||||
|
public boolean trackScores() {
|
||||||
|
return trackScores;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add an aggregation to perform as part of the search.
|
||||||
*/
|
*/
|
||||||
public NewSearchSourceBuilder aggregation(AbstractAggregationBuilder aggregation) throws IOException {
|
public NewSearchSourceBuilder aggregation(AbstractAggregationBuilder aggregation) throws IOException {
|
||||||
if (aggregations == null) {
|
if (aggregations == null) {
|
||||||
|
@ -300,6 +367,13 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the bytes representing the aggregation builders for this request.
|
||||||
|
*/
|
||||||
|
public List<BytesReference> aggregations() {
|
||||||
|
return aggregations;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set the rescore window size for rescores that don't specify their window.
|
* Set the rescore window size for rescores that don't specify their window.
|
||||||
*/
|
*/
|
||||||
|
@ -308,6 +382,13 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the rescore window size for rescores that don't specify their window.
|
||||||
|
*/
|
||||||
|
public int defaultRescoreWindowSize() {
|
||||||
|
return defaultRescoreWindowSize;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adds highlight to perform as part of the search.
|
* Adds highlight to perform as part of the search.
|
||||||
*/
|
*/
|
||||||
|
@ -318,6 +399,13 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the bytes representing the hightlighter builder for this request.
|
||||||
|
*/
|
||||||
|
public BytesReference highlight() {
|
||||||
|
return highlightBuilder;
|
||||||
|
}
|
||||||
|
|
||||||
public NewSearchSourceBuilder innerHits(InnerHitsBuilder innerHitsBuilder) throws IOException {
|
public NewSearchSourceBuilder innerHits(InnerHitsBuilder innerHitsBuilder) throws IOException {
|
||||||
XContentBuilder builder = XContentFactory.jsonBuilder();
|
XContentBuilder builder = XContentFactory.jsonBuilder();
|
||||||
innerHitsBuilder.toXContent(builder, EMPTY_PARAMS);
|
innerHitsBuilder.toXContent(builder, EMPTY_PARAMS);
|
||||||
|
@ -325,6 +413,13 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the bytes representing the inner hits builder for this request.
|
||||||
|
*/
|
||||||
|
public BytesReference innerHits() {
|
||||||
|
return innerHitsBuilder;
|
||||||
|
}
|
||||||
|
|
||||||
public NewSearchSourceBuilder suggest(SuggestBuilder suggestBuilder) throws IOException {
|
public NewSearchSourceBuilder suggest(SuggestBuilder suggestBuilder) throws IOException {
|
||||||
XContentBuilder builder = XContentFactory.jsonBuilder();
|
XContentBuilder builder = XContentFactory.jsonBuilder();
|
||||||
suggestBuilder.toXContent(builder, EMPTY_PARAMS);
|
suggestBuilder.toXContent(builder, EMPTY_PARAMS);
|
||||||
|
@ -332,6 +427,13 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the bytes representing the suggester builder for this request.
|
||||||
|
*/
|
||||||
|
public BytesReference suggest() {
|
||||||
|
return suggestBuilder;
|
||||||
|
}
|
||||||
|
|
||||||
public NewSearchSourceBuilder addRescorer(RescoreBuilder rescoreBuilder) throws IOException {
|
public NewSearchSourceBuilder addRescorer(RescoreBuilder rescoreBuilder) throws IOException {
|
||||||
if (rescoreBuilders == null) {
|
if (rescoreBuilders == null) {
|
||||||
rescoreBuilders = new ArrayList<>();
|
rescoreBuilders = new ArrayList<>();
|
||||||
|
@ -347,6 +449,13 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the bytes representing the rescore builders for this request.
|
||||||
|
*/
|
||||||
|
public List<BytesReference> rescores() {
|
||||||
|
return rescoreBuilders;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Indicates whether the response should contain the stored _source for
|
* Indicates whether the response should contain the stored _source for
|
||||||
* every hit
|
* every hit
|
||||||
|
@ -402,6 +511,14 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the {@link FetchSourceContext} which defines how the _source should
|
||||||
|
* be fetched.
|
||||||
|
*/
|
||||||
|
public FetchSourceContext fetchSource() {
|
||||||
|
return fetchSourceContext;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets no fields to be loaded, resulting in only id and type to be returned
|
* Sets no fields to be loaded, resulting in only id and type to be returned
|
||||||
* per field.
|
* per field.
|
||||||
|
@ -433,16 +550,10 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adds a field to load and return (note, it must be stored) as part of the
|
* Gets the fields to load and return as part of the search request.
|
||||||
* search request. If none are specified, the source of the document will be
|
|
||||||
* return.
|
|
||||||
*/
|
*/
|
||||||
public NewSearchSourceBuilder field(String name) {
|
public List<String> fieldNames() {
|
||||||
if (fieldNames == null) {
|
return fieldNames;
|
||||||
fieldNames = new ArrayList<>();
|
|
||||||
}
|
|
||||||
fieldNames.add(name);
|
|
||||||
return this;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -457,6 +568,13 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the field-data fields.
|
||||||
|
*/
|
||||||
|
public List<String> fieldDataFields() {
|
||||||
|
return fieldDataFields;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adds a script field under the given name with the provided script.
|
* Adds a script field under the given name with the provided script.
|
||||||
*
|
*
|
||||||
|
@ -473,6 +591,13 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the script fields.
|
||||||
|
*/
|
||||||
|
public List<ScriptField> scriptFields() {
|
||||||
|
return scriptFields;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the boost a specific index will receive when the query is executeed
|
* Sets the boost a specific index will receive when the query is executeed
|
||||||
* against it.
|
* against it.
|
||||||
|
@ -490,6 +615,14 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the boost a specific indices will receive when the query is
|
||||||
|
* executeed against them.
|
||||||
|
*/
|
||||||
|
public ObjectFloatHashMap<String> indexBoost() {
|
||||||
|
return indexBoost;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The stats groups this request will be aggregated under.
|
* The stats groups this request will be aggregated under.
|
||||||
*/
|
*/
|
||||||
|
@ -498,6 +631,13 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The stats groups this request will be aggregated under.
|
||||||
|
*/
|
||||||
|
public String[] stats() {
|
||||||
|
return stats;
|
||||||
|
}
|
||||||
|
|
||||||
public NewSearchSourceBuilder fromXContent(XContentParser parser, QueryParseContext context) throws IOException {
|
public NewSearchSourceBuilder fromXContent(XContentParser parser, QueryParseContext context) throws IOException {
|
||||||
NewSearchSourceBuilder builder = new NewSearchSourceBuilder();
|
NewSearchSourceBuilder builder = new NewSearchSourceBuilder();
|
||||||
XContentParser.Token token;
|
XContentParser.Token token;
|
||||||
|
@ -579,7 +719,21 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
}
|
}
|
||||||
builder.indexBoost = indexBoost;
|
builder.indexBoost = indexBoost;
|
||||||
} else if (context.parseFieldMatcher().match(currentFieldName, AGGREGATIONS_FIELD)) {
|
} else if (context.parseFieldMatcher().match(currentFieldName, AGGREGATIONS_FIELD)) {
|
||||||
// NOCOMMIT implement aggregations parsing
|
List<BytesReference> aggregations = new ArrayList<>();
|
||||||
|
while ((token = parser.nextToken()) != XContentParser.Token.END_OBJECT) {
|
||||||
|
currentFieldName = parser.currentName();
|
||||||
|
token = parser.nextToken();
|
||||||
|
if (token == XContentParser.Token.START_OBJECT) {
|
||||||
|
XContentBuilder xContentBuilder = XContentFactory.contentBuilder(parser.contentType());
|
||||||
|
xContentBuilder.field(currentFieldName);
|
||||||
|
xContentBuilder.copyCurrentStructure(parser);
|
||||||
|
aggregations.add(xContentBuilder.bytes());
|
||||||
|
} else {
|
||||||
|
throw new QueryParsingException(context, "Unknown key for a " + token + " in [" + currentFieldName + "].",
|
||||||
|
parser.getTokenLocation());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
builder.indexBoost = indexBoost;
|
||||||
} else if (context.parseFieldMatcher().match(currentFieldName, HIGHLIGHT_FIELD)) {
|
} else if (context.parseFieldMatcher().match(currentFieldName, HIGHLIGHT_FIELD)) {
|
||||||
XContentBuilder xContentBuilder = XContentFactory.contentBuilder(parser.contentType()).copyCurrentStructure(parser);
|
XContentBuilder xContentBuilder = XContentFactory.contentBuilder(parser.contentType()).copyCurrentStructure(parser);
|
||||||
builder.highlightBuilder = xContentBuilder.bytes();
|
builder.highlightBuilder = xContentBuilder.bytes();
|
||||||
|
@ -1032,7 +1186,7 @@ public class NewSearchSourceBuilder extends ToXContentToBytes implements Writeab
|
||||||
out.writeBytesReference(suggestBuilder);
|
out.writeBytesReference(suggestBuilder);
|
||||||
}
|
}
|
||||||
out.writeVInt(terminateAfter);
|
out.writeVInt(terminateAfter);
|
||||||
out.writeVLong(timeoutInMillis);
|
out.writeLong(timeoutInMillis);
|
||||||
out.writeBoolean(trackScores);
|
out.writeBoolean(trackScores);
|
||||||
out.writeBoolean(version);
|
out.writeBoolean(version);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue