Query refactoring: Adding getBuilderPrototype() method to all QueryParsers
Currently there is a registry for all QueryParsers accessible via the IndicesQueriesModule. For deserializing nested queries e.g. for the BoolQueryBuilder (#11121) we need to look up query builders by their name to be able to deserialize using a prototype builder of the concrete class. This PR adds a getBuilderPrototype() method to each query parser so we can re-use the parser registry to get the corresponding builder using the query name. Closes #11344
This commit is contained in:
parent
f1a6858081
commit
8a37cc2a3c
|
@ -39,6 +39,8 @@ public class AndQueryBuilder extends QueryBuilder {
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final AndQueryBuilder PROTOTYPE = new AndQueryBuilder();
|
||||
|
||||
public AndQueryBuilder(QueryBuilder... filters) {
|
||||
for (QueryBuilder filter : filters) {
|
||||
this.filters.add(filter);
|
||||
|
|
|
@ -115,4 +115,9 @@ public class AndQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public AndQueryBuilder getBuilderPrototype() {
|
||||
return AndQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
|
@ -51,6 +51,8 @@ public class BoolQueryBuilder extends QueryBuilder implements BoostableQueryBuil
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final BoolQueryBuilder PROTOTYPE = new BoolQueryBuilder();
|
||||
|
||||
/**
|
||||
* Adds a query that <b>must</b> appear in the matching documents and will
|
||||
* contribute to scoring.
|
||||
|
|
|
@ -171,4 +171,9 @@ public class BoolQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public BoolQueryBuilder getBuilderPrototype() {
|
||||
return BoolQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -47,8 +47,9 @@ public class BoostingQueryBuilder extends QueryBuilder implements BoostableQuery
|
|||
|
||||
private float boost = -1;
|
||||
|
||||
public BoostingQueryBuilder() {
|
||||
static final BoostingQueryBuilder PROTOTYPE = new BoostingQueryBuilder();
|
||||
|
||||
public BoostingQueryBuilder() {
|
||||
}
|
||||
|
||||
public BoostingQueryBuilder positive(QueryBuilder positiveQuery) {
|
||||
|
|
|
@ -98,4 +98,9 @@ public class BoostingQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return boostingQuery;
|
||||
}
|
||||
|
||||
@Override
|
||||
public BoostingQueryBuilder getBuilderPrototype() {
|
||||
return BoostingQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
|
@ -72,6 +72,8 @@ public class CommonTermsQueryBuilder extends QueryBuilder implements BoostableQu
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final CommonTermsQueryBuilder PROTOTYPE = new CommonTermsQueryBuilder();
|
||||
|
||||
/**
|
||||
* Constructs a new common terms query.
|
||||
*/
|
||||
|
@ -86,6 +88,14 @@ public class CommonTermsQueryBuilder extends QueryBuilder implements BoostableQu
|
|||
this.name = name;
|
||||
}
|
||||
|
||||
/**
|
||||
* private constructor used onyl internally
|
||||
*/
|
||||
private CommonTermsQueryBuilder() {
|
||||
this.text = null;
|
||||
this.name = null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the operator to use for terms with a high document frequency
|
||||
* (greater than or equal to {@link #cutoffFrequency(float)}. Defaults to
|
||||
|
|
|
@ -219,4 +219,9 @@ public class CommonTermsQueryParser extends BaseQueryParserTemp {
|
|||
query.setHighFreqMinimumNumberShouldMatch(highFreqMinimumShouldMatch);
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public CommonTermsQueryBuilder getBuilderPrototype() {
|
||||
return CommonTermsQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -37,6 +37,8 @@ public class ConstantScoreQueryBuilder extends QueryBuilder implements Boostable
|
|||
|
||||
private float boost = -1;
|
||||
|
||||
static final ConstantScoreQueryBuilder PROTOTYPE = new ConstantScoreQueryBuilder();
|
||||
|
||||
/**
|
||||
* A query that wraps a query and simply returns a constant score equal to the
|
||||
* query boost for every document in the query.
|
||||
|
@ -47,6 +49,13 @@ public class ConstantScoreQueryBuilder extends QueryBuilder implements Boostable
|
|||
this.filterBuilder = Objects.requireNonNull(filterBuilder);
|
||||
}
|
||||
|
||||
/**
|
||||
* private constructor only used for serialization
|
||||
*/
|
||||
private ConstantScoreQueryBuilder() {
|
||||
this.filterBuilder = null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the boost for this query. Documents matching this query will (in addition to the normal
|
||||
* weightings) have their score multiplied by the boost provided.
|
||||
|
|
|
@ -86,4 +86,9 @@ public class ConstantScoreQueryParser extends BaseQueryParserTemp {
|
|||
filter.setBoost(boost);
|
||||
return filter;
|
||||
}
|
||||
|
||||
@Override
|
||||
public ConstantScoreQueryBuilder getBuilderPrototype() {
|
||||
return ConstantScoreQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -43,6 +43,8 @@ public class DisMaxQueryBuilder extends QueryBuilder implements BoostableQueryBu
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final DisMaxQueryBuilder PROTOTYPE = new DisMaxQueryBuilder();
|
||||
|
||||
/**
|
||||
* Add a sub-query to this disjunction.
|
||||
*/
|
||||
|
|
|
@ -111,4 +111,9 @@ public class DisMaxQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public DisMaxQueryBuilder getBuilderPrototype() {
|
||||
return DisMaxQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -34,6 +34,8 @@ public class ExistsQueryBuilder extends QueryBuilder {
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final ExistsQueryBuilder PROTOTYPE = new ExistsQueryBuilder(null);
|
||||
|
||||
public ExistsQueryBuilder(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
|
|
@ -122,4 +122,9 @@ public class ExistsQueryParser extends BaseQueryParserTemp {
|
|||
return new ConstantScoreQuery(boolFilter);
|
||||
}
|
||||
|
||||
@Override
|
||||
public ExistsQueryBuilder getBuilderPrototype() {
|
||||
return ExistsQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -84,4 +84,9 @@ public class FQueryFilterParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public QueryFilterBuilder getBuilderPrototype() {
|
||||
return QueryFilterBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -35,6 +35,8 @@ public class FieldMaskingSpanQueryBuilder extends QueryBuilder implements SpanQu
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final FieldMaskingSpanQueryBuilder PROTOTYPE = new FieldMaskingSpanQueryBuilder(null, null);
|
||||
|
||||
public FieldMaskingSpanQueryBuilder(SpanQueryBuilder queryBuilder, String field) {
|
||||
this.queryBuilder = queryBuilder;
|
||||
this.field = field;
|
||||
|
|
|
@ -100,4 +100,9 @@ public class FieldMaskingSpanQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public FieldMaskingSpanQueryBuilder getBuilderPrototype() {
|
||||
return FieldMaskingSpanQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -41,6 +41,8 @@ public class FilteredQueryBuilder extends QueryBuilder implements BoostableQuery
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final FilteredQueryBuilder PROTOTYPE = new FilteredQueryBuilder(null, null);
|
||||
|
||||
/**
|
||||
* A query that applies a filter to the results of another query.
|
||||
*
|
||||
|
|
|
@ -118,4 +118,9 @@ public class FilteredQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return filteredQuery;
|
||||
}
|
||||
|
||||
@Override
|
||||
public FilteredQueryBuilder getBuilderPrototype() {
|
||||
return FilteredQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -50,6 +50,8 @@ public class FuzzyQueryBuilder extends MultiTermQueryBuilder implements Boostabl
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final FuzzyQueryBuilder PROTOTYPE = new FuzzyQueryBuilder(null, null);
|
||||
|
||||
/**
|
||||
* Constructs a new term query.
|
||||
*
|
||||
|
|
|
@ -130,4 +130,9 @@ public class FuzzyQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public FuzzyQueryBuilder getBuilderPrototype() {
|
||||
return FuzzyQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -44,6 +44,8 @@ public class GeoBoundingBoxQueryBuilder extends QueryBuilder {
|
|||
private String queryName;
|
||||
private String type;
|
||||
|
||||
static final GeoBoundingBoxQueryBuilder PROTOTYPE = new GeoBoundingBoxQueryBuilder(null);
|
||||
|
||||
public GeoBoundingBoxQueryBuilder(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
|
|
@ -184,4 +184,9 @@ public class GeoBoundingBoxQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return filter;
|
||||
}
|
||||
|
||||
@Override
|
||||
public GeoBoundingBoxQueryBuilder getBuilderPrototype() {
|
||||
return GeoBoundingBoxQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -46,6 +46,8 @@ public class GeoDistanceQueryBuilder extends QueryBuilder {
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final GeoDistanceQueryBuilder PROTOTYPE = new GeoDistanceQueryBuilder(null);
|
||||
|
||||
public GeoDistanceQueryBuilder(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
|
|
@ -162,4 +162,9 @@ public class GeoDistanceQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public GeoDistanceQueryBuilder getBuilderPrototype() {
|
||||
return GeoDistanceQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -48,6 +48,8 @@ public class GeoDistanceRangeQueryBuilder extends QueryBuilder {
|
|||
|
||||
private String optimizeBbox;
|
||||
|
||||
static final GeoDistanceRangeQueryBuilder PROTOTYPE = new GeoDistanceRangeQueryBuilder(null);
|
||||
|
||||
public GeoDistanceRangeQueryBuilder(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
|
|
@ -201,4 +201,9 @@ public class GeoDistanceRangeQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public GeoDistanceRangeQueryBuilder getBuilderPrototype() {
|
||||
return GeoDistanceRangeQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -40,6 +40,8 @@ public class GeoPolygonQueryBuilder extends QueryBuilder {
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final GeoPolygonQueryBuilder PROTOTYPE = new GeoPolygonQueryBuilder(null);
|
||||
|
||||
public GeoPolygonQueryBuilder(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
|
|
@ -150,4 +150,9 @@ public class GeoPolygonQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public GeoPolygonQueryBuilder getBuilderPrototype() {
|
||||
return GeoPolygonQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -49,6 +49,8 @@ public class GeoShapeQueryBuilder extends QueryBuilder {
|
|||
|
||||
private ShapeRelation relation = null;
|
||||
|
||||
static final GeoShapeQueryBuilder PROTOTYPE = new GeoShapeQueryBuilder(null, null);
|
||||
|
||||
/**
|
||||
* Creates a new GeoShapeQueryBuilder whose Filter will be against the
|
||||
* given field name using the given Shape
|
||||
|
|
|
@ -189,4 +189,9 @@ public class GeoShapeQueryParser extends BaseQueryParserTemp {
|
|||
throw new IllegalArgumentException("");
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public GeoShapeQueryBuilder getBuilderPrototype() {
|
||||
return GeoShapeQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -98,6 +98,7 @@ public class GeohashCellQuery {
|
|||
private String geohash;
|
||||
private int levels = -1;
|
||||
private boolean neighbors;
|
||||
private static final Builder PROTOTYPE = new Builder(null);
|
||||
|
||||
|
||||
public Builder(String field) {
|
||||
|
@ -270,5 +271,10 @@ public class GeohashCellQuery {
|
|||
|
||||
return filter;
|
||||
}
|
||||
|
||||
@Override
|
||||
public GeohashCellQuery.Builder getBuilderPrototype() {
|
||||
return Builder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -45,6 +45,8 @@ public class HasChildQueryBuilder extends QueryBuilder implements BoostableQuery
|
|||
|
||||
private QueryInnerHitBuilder innerHit = null;
|
||||
|
||||
static final HasChildQueryBuilder PROTOTYPE = new HasChildQueryBuilder(null, null);
|
||||
|
||||
public HasChildQueryBuilder(String type, QueryBuilder queryBuilder) {
|
||||
this.childType = type;
|
||||
this.queryBuilder = queryBuilder;
|
||||
|
|
|
@ -187,4 +187,9 @@ public class HasChildQueryParser extends BaseQueryParserTemp {
|
|||
query.setBoost(boost);
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public HasChildQueryBuilder getBuilderPrototype() {
|
||||
return HasChildQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -35,6 +35,7 @@ public class HasParentQueryBuilder extends QueryBuilder implements BoostableQuer
|
|||
private float boost = 1.0f;
|
||||
private String queryName;
|
||||
private QueryInnerHitBuilder innerHit = null;
|
||||
static final HasParentQueryBuilder PROTOTYPE = new HasParentQueryBuilder(null, null);
|
||||
|
||||
/**
|
||||
* @param parentType The parent type
|
||||
|
|
|
@ -203,4 +203,9 @@ public class HasParentQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public HasParentQueryBuilder getBuilderPrototype() {
|
||||
return HasParentQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -20,6 +20,7 @@
|
|||
package org.elasticsearch.index.query;
|
||||
|
||||
import com.google.common.collect.Sets;
|
||||
|
||||
import org.apache.lucene.queries.TermsQuery;
|
||||
import org.apache.lucene.search.Query;
|
||||
import org.elasticsearch.cluster.metadata.MetaData;
|
||||
|
@ -49,6 +50,8 @@ public class IdsQueryBuilder extends QueryBuilder<IdsQueryBuilder> implements Bo
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final IdsQueryBuilder PROTOTYPE = new IdsQueryBuilder();
|
||||
|
||||
/**
|
||||
* Creates a new IdsQueryBuilder by optionally providing the types of the documents to look for
|
||||
*/
|
||||
|
|
|
@ -107,4 +107,9 @@ public class IdsQueryParser extends BaseQueryParser {
|
|||
query.validate();
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public IdsQueryBuilder getBuilderPrototype() {
|
||||
return IdsQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -40,6 +40,8 @@ public class IndicesQueryBuilder extends QueryBuilder {
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final IndicesQueryBuilder PROTOTYPE = new IndicesQueryBuilder(null);
|
||||
|
||||
public IndicesQueryBuilder(QueryBuilder queryBuilder, String... indices) {
|
||||
this.queryBuilder = queryBuilder;
|
||||
this.indices = indices;
|
||||
|
|
|
@ -157,4 +157,9 @@ public class IndicesQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public IndicesQueryBuilder getBuilderPrototype() {
|
||||
return IndicesQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -32,6 +32,7 @@ public class LimitQueryBuilder extends QueryBuilder {
|
|||
|
||||
public static final String NAME = "limit";
|
||||
private final int limit;
|
||||
static final LimitQueryBuilder PROTOTYPE = new LimitQueryBuilder(-1);
|
||||
|
||||
public LimitQueryBuilder(int limit) {
|
||||
this.limit = limit;
|
||||
|
|
|
@ -64,4 +64,9 @@ public class LimitQueryParser extends BaseQueryParserTemp {
|
|||
// this filter is deprecated and parses to a filter that matches everything
|
||||
return Queries.newMatchAllQuery();
|
||||
}
|
||||
|
||||
@Override
|
||||
public LimitQueryBuilder getBuilderPrototype() {
|
||||
return LimitQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -37,6 +37,8 @@ public class MatchAllQueryBuilder extends QueryBuilder<MatchAllQueryBuilder> imp
|
|||
|
||||
private float boost = 1.0f;
|
||||
|
||||
static final MatchAllQueryBuilder PROTOTYPE = new MatchAllQueryBuilder();
|
||||
|
||||
/**
|
||||
* Sets the boost for this query. Documents matching this query will (in addition to the normal
|
||||
* weightings) have their score multiplied by the boost provided.
|
||||
|
|
|
@ -59,4 +59,9 @@ public class MatchAllQueryParser extends BaseQueryParser {
|
|||
}
|
||||
return queryBuilder;
|
||||
}
|
||||
|
||||
@Override
|
||||
public MatchAllQueryBuilder getBuilderPrototype() {
|
||||
return MatchAllQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -94,6 +94,8 @@ public class MatchQueryBuilder extends QueryBuilder implements BoostableQueryBui
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final MatchQueryBuilder PROTOTYPE = new MatchQueryBuilder(null, null);
|
||||
|
||||
/**
|
||||
* Constructs a new text query.
|
||||
*/
|
||||
|
|
|
@ -178,4 +178,9 @@ public class MatchQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public MatchQueryBuilder getBuilderPrototype() {
|
||||
return MatchQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -38,6 +38,8 @@ public class MissingQueryBuilder extends QueryBuilder {
|
|||
|
||||
private Boolean existence;
|
||||
|
||||
static final MissingQueryBuilder PROTOTYPE = new MissingQueryBuilder(null);
|
||||
|
||||
public MissingQueryBuilder(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
|
|
@ -172,4 +172,9 @@ public class MissingQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return new ConstantScoreQuery(filter);
|
||||
}
|
||||
|
||||
@Override
|
||||
public MissingQueryBuilder getBuilderPrototype() {
|
||||
return MissingQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -152,6 +152,8 @@ public class MoreLikeThisQueryBuilder extends QueryBuilder implements BoostableQ
|
|||
private Boolean failOnUnsupportedField;
|
||||
private String queryName;
|
||||
|
||||
static final MoreLikeThisQueryBuilder PROTOTYPE = new MoreLikeThisQueryBuilder();
|
||||
|
||||
/**
|
||||
* Constructs a new more like this query which uses the "_all" field.
|
||||
*/
|
||||
|
|
|
@ -355,4 +355,9 @@ public class MoreLikeThisQueryParser extends BaseQueryParserTemp {
|
|||
boolQuery.add(query, BooleanClause.Occur.MUST_NOT);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public MoreLikeThisQueryBuilder getBuilderPrototype() {
|
||||
return MoreLikeThisQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -80,6 +80,8 @@ public class MultiMatchQueryBuilder extends QueryBuilder implements BoostableQue
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final MultiMatchQueryBuilder PROTOTYPE = new MultiMatchQueryBuilder(null);
|
||||
|
||||
public enum Type {
|
||||
|
||||
/**
|
||||
|
|
|
@ -197,4 +197,9 @@ public class MultiMatchQueryParser extends BaseQueryParserTemp {
|
|||
fieldNameWithBoosts.put(fField, fBoost);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public MultiMatchQueryBuilder getBuilderPrototype() {
|
||||
return MultiMatchQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -41,10 +41,21 @@ public class NestedQueryBuilder extends QueryBuilder implements BoostableQueryBu
|
|||
|
||||
private QueryInnerHitBuilder innerHit;
|
||||
|
||||
static final NestedQueryBuilder PROTOTYPE = new NestedQueryBuilder();
|
||||
|
||||
public NestedQueryBuilder(String path, QueryBuilder queryBuilder) {
|
||||
this.path = path;
|
||||
this.queryBuilder = Objects.requireNonNull(queryBuilder);
|
||||
}
|
||||
|
||||
/**
|
||||
* private constructor only used internally
|
||||
*/
|
||||
private NestedQueryBuilder() {
|
||||
this.path = null;
|
||||
this.queryBuilder = null;
|
||||
}
|
||||
|
||||
/**
|
||||
* The score mode.
|
||||
*/
|
||||
|
|
|
@ -161,4 +161,9 @@ public class NestedQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public NestedQueryBuilder getBuilderPrototype() {
|
||||
return NestedQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -35,10 +35,19 @@ public class NotQueryBuilder extends QueryBuilder {
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final NotQueryBuilder PROTOTYPE = new NotQueryBuilder();
|
||||
|
||||
public NotQueryBuilder(QueryBuilder filter) {
|
||||
this.filter = Objects.requireNonNull(filter);
|
||||
}
|
||||
|
||||
/**
|
||||
* private constructor for internal use
|
||||
*/
|
||||
private NotQueryBuilder() {
|
||||
this.filter = null;
|
||||
}
|
||||
|
||||
public NotQueryBuilder queryName(String queryName) {
|
||||
this.queryName = queryName;
|
||||
return this;
|
||||
|
|
|
@ -94,4 +94,9 @@ public class NotQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return notQuery;
|
||||
}
|
||||
|
||||
@Override
|
||||
public NotQueryBuilder getBuilderPrototype() {
|
||||
return NotQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
|
@ -40,6 +40,8 @@ public class OrQueryBuilder extends QueryBuilder {
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final OrQueryBuilder PROTOTYPE = new OrQueryBuilder();
|
||||
|
||||
public OrQueryBuilder(QueryBuilder... filters) {
|
||||
Collections.addAll(this.filters, filters);
|
||||
}
|
||||
|
|
|
@ -112,4 +112,9 @@ public class OrQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public OrQueryBuilder getBuilderPrototype() {
|
||||
return OrQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
|
@ -40,6 +40,8 @@ public class PrefixQueryBuilder extends MultiTermQueryBuilder implements Boostab
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final PrefixQueryBuilder PROTOTYPE = new PrefixQueryBuilder(null, null);
|
||||
|
||||
/**
|
||||
* A Query that matches documents containing terms with a specified prefix.
|
||||
*
|
||||
|
|
|
@ -115,4 +115,9 @@ public class PrefixQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public PrefixQueryBuilder getBuilderPrototype() {
|
||||
return PrefixQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -40,6 +40,8 @@ public class QueryFilterBuilder extends QueryBuilder {
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final QueryFilterBuilder PROTOTYPE = new QueryFilterBuilder(null);
|
||||
|
||||
/**
|
||||
* A filter that simply wraps a query.
|
||||
*
|
||||
|
|
|
@ -41,4 +41,9 @@ public class QueryFilterParser extends BaseQueryParserTemp {
|
|||
public Query parse(QueryParseContext parseContext) throws IOException, QueryParsingException {
|
||||
return new ConstantScoreQuery(parseContext.parseInnerQuery());
|
||||
}
|
||||
|
||||
@Override
|
||||
public QueryFilterBuilder getBuilderPrototype() {
|
||||
return QueryFilterBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
|
@ -59,4 +59,9 @@ public interface QueryParser {
|
|||
* @throws QueryParsingException
|
||||
*/
|
||||
QueryBuilder fromXContent(QueryParseContext parseContext) throws IOException, QueryParsingException;
|
||||
|
||||
/**
|
||||
* @return an empty {@link QueryBuilder} instance for this parser that can be used for deserialization
|
||||
*/
|
||||
QueryBuilder getBuilderPrototype();
|
||||
}
|
||||
|
|
|
@ -101,6 +101,8 @@ public class QueryStringQueryBuilder extends QueryBuilder implements BoostableQu
|
|||
/** To limit effort spent determinizing regexp queries. */
|
||||
private Integer maxDeterminizedStates;
|
||||
|
||||
static final QueryStringQueryBuilder PROTOTYPE = new QueryStringQueryBuilder(null);
|
||||
|
||||
public QueryStringQueryBuilder(String queryString) {
|
||||
this.queryString = queryString;
|
||||
}
|
||||
|
|
|
@ -245,4 +245,9 @@ public class QueryStringQueryParser extends BaseQueryParserTemp {
|
|||
throw new QueryParsingException(parseContext, "Failed to parse query [" + qpSettings.queryString() + "]", e);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public QueryStringQueryBuilder getBuilderPrototype() {
|
||||
return QueryStringQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -59,6 +59,8 @@ public class RangeQueryBuilder extends MultiTermQueryBuilder<RangeQueryBuilder>
|
|||
|
||||
private String format;
|
||||
|
||||
static final RangeQueryBuilder PROTOTYPE = new RangeQueryBuilder(null);
|
||||
|
||||
/**
|
||||
* A Query that matches documents within an range of terms.
|
||||
*
|
||||
|
|
|
@ -19,12 +19,9 @@
|
|||
|
||||
package org.elasticsearch.index.query;
|
||||
|
||||
import org.apache.lucene.search.TermRangeQuery;
|
||||
import org.elasticsearch.common.ParseField;
|
||||
import org.elasticsearch.common.inject.Inject;
|
||||
import org.elasticsearch.common.xcontent.XContentParser;
|
||||
import org.elasticsearch.index.mapper.FieldMapper;
|
||||
import org.elasticsearch.index.mapper.core.DateFieldMapper;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
|
@ -125,4 +122,9 @@ public class RangeQueryParser extends BaseQueryParser {
|
|||
rangeQuery.validate();
|
||||
return rangeQuery;
|
||||
}
|
||||
|
||||
@Override
|
||||
public RangeQueryBuilder getBuilderPrototype() {
|
||||
return RangeQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -39,6 +39,7 @@ public class RegexpQueryBuilder extends MultiTermQueryBuilder implements Boostab
|
|||
private String queryName;
|
||||
private int maxDeterminizedStates = Operations.DEFAULT_MAX_DETERMINIZED_STATES;
|
||||
private boolean maxDetermizedStatesSet;
|
||||
static final RegexpQueryBuilder PROTOTYPE = new RegexpQueryBuilder(null, null);
|
||||
|
||||
/**
|
||||
* Constructs a new term query.
|
||||
|
|
|
@ -124,5 +124,10 @@ public class RegexpQueryParser extends BaseQueryParserTemp {
|
|||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public RegexpQueryBuilder getBuilderPrototype() {
|
||||
return RegexpQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
|
|
@ -38,6 +38,8 @@ public class ScriptQueryBuilder extends QueryBuilder {
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final ScriptQueryBuilder PROTOTYPE = new ScriptQueryBuilder(null);
|
||||
|
||||
public ScriptQueryBuilder(String script) {
|
||||
this.script = script;
|
||||
}
|
||||
|
|
|
@ -189,4 +189,9 @@ public class ScriptQueryParser extends BaseQueryParserTemp {
|
|||
};
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public ScriptQueryBuilder getBuilderPrototype() {
|
||||
return ScriptQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -43,6 +43,7 @@ public class SimpleQueryStringBuilder extends QueryBuilder {
|
|||
private Boolean lenient;
|
||||
private Boolean analyzeWildcard;
|
||||
private Locale locale;
|
||||
static final SimpleQueryStringBuilder PROTOTYPE = new SimpleQueryStringBuilder(null);
|
||||
|
||||
/**
|
||||
* Operators for the default_operator
|
||||
|
|
|
@ -230,4 +230,9 @@ public class SimpleQueryStringParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public SimpleQueryStringBuilder getBuilderPrototype() {
|
||||
return SimpleQueryStringBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -33,6 +33,7 @@ public class SpanContainingQueryBuilder extends QueryBuilder implements SpanQuer
|
|||
private SpanQueryBuilder little;
|
||||
private float boost = -1;
|
||||
private String queryName;
|
||||
static final SpanContainingQueryBuilder PROTOTYPE = new SpanContainingQueryBuilder();
|
||||
|
||||
/**
|
||||
* Sets the little clause, it must be contained within {@code big} for a match.
|
||||
|
|
|
@ -95,4 +95,9 @@ public class SpanContainingQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public SpanContainingQueryBuilder getBuilderPrototype() {
|
||||
return SpanContainingQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -35,6 +35,8 @@ public class SpanFirstQueryBuilder extends QueryBuilder implements SpanQueryBuil
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final SpanFirstQueryBuilder SPAN_FIRST_QUERY_BUILDER = new SpanFirstQueryBuilder(null, -1);
|
||||
|
||||
public SpanFirstQueryBuilder(SpanQueryBuilder matchBuilder, int end) {
|
||||
this.matchBuilder = matchBuilder;
|
||||
this.end = end;
|
||||
|
|
|
@ -93,4 +93,9 @@ public class SpanFirstQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public SpanFirstQueryBuilder getBuilderPrototype() {
|
||||
return SpanFirstQueryBuilder.SPAN_FIRST_QUERY_BUILDER;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -26,6 +26,7 @@ public class SpanMultiTermQueryBuilder extends QueryBuilder implements SpanQuery
|
|||
|
||||
public static final String NAME = "span_multi";
|
||||
private MultiTermQueryBuilder multiTermQueryBuilder;
|
||||
static final SpanMultiTermQueryBuilder PROTOTYPE = new SpanMultiTermQueryBuilder(null);
|
||||
|
||||
public SpanMultiTermQueryBuilder(MultiTermQueryBuilder multiTermQueryBuilder) {
|
||||
this.multiTermQueryBuilder = multiTermQueryBuilder;
|
||||
|
|
|
@ -66,4 +66,9 @@ public class SpanMultiTermQueryParser extends BaseQueryParserTemp {
|
|||
parser.nextToken();
|
||||
return new SpanMultiTermQueryWrapper<>((MultiTermQuery) subQuery);
|
||||
}
|
||||
|
||||
@Override
|
||||
public SpanMultiTermQueryBuilder getBuilderPrototype() {
|
||||
return SpanMultiTermQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -40,6 +40,8 @@ public class SpanNearQueryBuilder extends QueryBuilder implements SpanQueryBuild
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final SpanNearQueryBuilder PROTOTYPE = new SpanNearQueryBuilder();
|
||||
|
||||
public SpanNearQueryBuilder clause(SpanQueryBuilder clause) {
|
||||
clauses.add(clause);
|
||||
return this;
|
||||
|
|
|
@ -106,4 +106,9 @@ public class SpanNearQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public SpanNearQueryBuilder getBuilderPrototype() {
|
||||
return SpanNearQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -41,6 +41,8 @@ public class SpanNotQueryBuilder extends QueryBuilder implements SpanQueryBuilde
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final SpanNotQueryBuilder PROTOTYPE = new SpanNotQueryBuilder();
|
||||
|
||||
public SpanNotQueryBuilder include(SpanQueryBuilder include) {
|
||||
this.include = include;
|
||||
return this;
|
||||
|
|
|
@ -126,4 +126,9 @@ public class SpanNotQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public SpanNotQueryBuilder getBuilderPrototype() {
|
||||
return SpanNotQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -34,6 +34,8 @@ public class SpanOrQueryBuilder extends QueryBuilder implements SpanQueryBuilder
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final SpanOrQueryBuilder PROTOTYPE = new SpanOrQueryBuilder();
|
||||
|
||||
public SpanOrQueryBuilder clause(SpanQueryBuilder clause) {
|
||||
clauses.add(clause);
|
||||
return this;
|
||||
|
|
|
@ -92,4 +92,9 @@ public class SpanOrQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public SpanOrQueryBuilder getBuilderPrototype() {
|
||||
return SpanOrQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -33,6 +33,7 @@ import org.elasticsearch.index.mapper.FieldMapper;
|
|||
public class SpanTermQueryBuilder extends BaseTermQueryBuilder<SpanTermQueryBuilder> implements SpanQueryBuilder {
|
||||
|
||||
public static final String NAME = "span_term";
|
||||
static final SpanTermQueryBuilder PROTOTYPE = new SpanTermQueryBuilder(null, null);
|
||||
|
||||
/** @see BaseTermQueryBuilder#BaseTermQueryBuilder(String, String) */
|
||||
public SpanTermQueryBuilder(String name, String value) {
|
||||
|
|
|
@ -92,4 +92,9 @@ public class SpanTermQueryParser extends BaseQueryParser {
|
|||
result.validate();
|
||||
return result;
|
||||
}
|
||||
|
||||
@Override
|
||||
public SpanTermQueryBuilder getBuilderPrototype() {
|
||||
return SpanTermQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -33,6 +33,7 @@ public class SpanWithinQueryBuilder extends QueryBuilder implements SpanQueryBui
|
|||
private SpanQueryBuilder little;
|
||||
private float boost = -1;
|
||||
private String queryName;
|
||||
static final SpanWithinQueryBuilder PROTOTYPE = new SpanWithinQueryBuilder();
|
||||
|
||||
/**
|
||||
* Sets the little clause, it must be contained within {@code big} for a match.
|
||||
|
|
|
@ -95,4 +95,9 @@ public class SpanWithinQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public SpanWithinQueryBuilder getBuilderPrototype() {
|
||||
return SpanWithinQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -39,6 +39,8 @@ public class TemplateQueryBuilder extends QueryBuilder {
|
|||
|
||||
private ScriptService.ScriptType templateType;
|
||||
|
||||
static final TemplateQueryBuilder PROTOTYPE = new TemplateQueryBuilder(null, null);
|
||||
|
||||
/**
|
||||
* @param template the template to use for that query.
|
||||
* @param vars the parameters to fill the template with.
|
||||
|
|
|
@ -155,4 +155,9 @@ public class TemplateQueryParser extends BaseQueryParserTemp {
|
|||
return type + " " + template;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public TemplateQueryBuilder getBuilderPrototype() {
|
||||
return TemplateQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -31,6 +31,7 @@ import org.elasticsearch.index.mapper.FieldMapper;
|
|||
public class TermQueryBuilder extends BaseTermQueryBuilder<TermQueryBuilder> implements BoostableQueryBuilder<TermQueryBuilder> {
|
||||
|
||||
public static final String NAME = "term";
|
||||
static final TermQueryBuilder PROTOTYPE = new TermQueryBuilder(null, null);
|
||||
|
||||
/** @see BaseTermQueryBuilder#BaseTermQueryBuilder(String, String) */
|
||||
public TermQueryBuilder(String fieldName, String value) {
|
||||
|
|
|
@ -19,7 +19,6 @@
|
|||
|
||||
package org.elasticsearch.index.query;
|
||||
|
||||
import org.apache.lucene.search.TermQuery;
|
||||
import org.elasticsearch.common.inject.Inject;
|
||||
import org.elasticsearch.common.xcontent.XContentParser;
|
||||
|
||||
|
@ -96,4 +95,9 @@ public class TermQueryParser extends BaseQueryParser {
|
|||
termQuery.validate();
|
||||
return termQuery;
|
||||
}
|
||||
|
||||
@Override
|
||||
public TermQueryBuilder getBuilderPrototype() {
|
||||
return TermQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -45,6 +45,8 @@ public class TermsQueryBuilder extends QueryBuilder<TermsQueryBuilder> {
|
|||
private String lookupPath;
|
||||
private Boolean lookupCache;
|
||||
|
||||
static final TermsQueryBuilder PROTOTYPE = new TermsQueryBuilder(null, (Object) null);
|
||||
|
||||
/**
|
||||
* A filter for a field based on several terms matching on any of them.
|
||||
*
|
||||
|
|
|
@ -207,4 +207,9 @@ public class TermsQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return query;
|
||||
}
|
||||
|
||||
@Override
|
||||
public TermsQueryBuilder getBuilderPrototype() {
|
||||
return TermsQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -27,6 +27,7 @@ public class TypeQueryBuilder extends QueryBuilder {
|
|||
|
||||
public static final String NAME = "type";
|
||||
private final String type;
|
||||
static final TypeQueryBuilder PROTOTYPE = new TypeQueryBuilder(null);
|
||||
|
||||
public TypeQueryBuilder(String type) {
|
||||
this.type = type;
|
||||
|
|
|
@ -71,4 +71,9 @@ public class TypeQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return filter;
|
||||
}
|
||||
|
||||
@Override
|
||||
public TypeQueryBuilder getBuilderPrototype() {
|
||||
return TypeQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
|
@ -45,6 +45,8 @@ public class WildcardQueryBuilder extends MultiTermQueryBuilder implements Boost
|
|||
|
||||
private String queryName;
|
||||
|
||||
static final WildcardQueryBuilder PROTOTYPE = new WildcardQueryBuilder(null, null);
|
||||
|
||||
/**
|
||||
* Implements the wildcard search query. Supported wildcards are <tt>*</tt>, which
|
||||
* matches any character sequence (including the empty one), and <tt>?</tt>,
|
||||
|
|
|
@ -108,4 +108,9 @@ public class WildcardQueryParser extends BaseQueryParserTemp {
|
|||
}
|
||||
return wildcardQuery;
|
||||
}
|
||||
|
||||
@Override
|
||||
public WildcardQueryBuilder getBuilderPrototype() {
|
||||
return WildcardQueryBuilder.PROTOTYPE;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -46,6 +46,7 @@ public class WrapperQueryBuilder extends QueryBuilder {
|
|||
private final byte[] source;
|
||||
private final int offset;
|
||||
private final int length;
|
||||
static final WrapperQueryBuilder PROTOTYPE = new WrapperQueryBuilder(null, -1, -1);
|
||||
|
||||
/**
|
||||
* Creates a query builder given a query provided as a string
|
||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue