mirror of
https://github.com/honeymoose/OpenSearch.git
synced 2025-04-02 05:18:49 +00:00
We have some builders, specifically query builders, `SearchSourceBuilder`, `QuerySourceBuilder` and `SuggestBuilder`, that implement `ToXContent` and also allow to build their content as bytes by simply creating a `BytesReference` that holds their json (or yaml etc.) content (`buildAsBytes` methods). They can also print out their content through `toString`. Made sure that those common methods are in one single place and reused where needed. Also, merged `QueryBuilder` and `BaseQueryBuilder` and made `QueryBuilder` an abstract class instead of an interface. Closes #11063
74 lines
2.3 KiB
Java
74 lines
2.3 KiB
Java
/*
|
|
* Licensed to Elasticsearch under one or more contributor
|
|
* license agreements. See the NOTICE file distributed with
|
|
* this work for additional information regarding copyright
|
|
* ownership. Elasticsearch licenses this file to you under
|
|
* the Apache License, Version 2.0 (the "License"); you may
|
|
* not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing,
|
|
* software distributed under the License is distributed on an
|
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
* KIND, either express or implied. See the License for the
|
|
* specific language governing permissions and limitations
|
|
* under the License.
|
|
*/
|
|
|
|
package org.elasticsearch.index.query;
|
|
|
|
import com.google.common.collect.Lists;
|
|
import org.elasticsearch.common.xcontent.XContentBuilder;
|
|
|
|
import java.io.IOException;
|
|
import java.util.ArrayList;
|
|
|
|
/**
|
|
* A filter that matches documents matching boolean combinations of other filters.
|
|
* @deprecated Use {@link BoolQueryBuilder} instead
|
|
*/
|
|
@Deprecated
|
|
public class AndQueryBuilder extends QueryBuilder {
|
|
|
|
private ArrayList<QueryBuilder> filters = Lists.newArrayList();
|
|
|
|
private String queryName;
|
|
|
|
public AndQueryBuilder(QueryBuilder... filters) {
|
|
for (QueryBuilder filter : filters) {
|
|
this.filters.add(filter);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Adds a filter to the list of filters to "and".
|
|
*/
|
|
public AndQueryBuilder add(QueryBuilder filterBuilder) {
|
|
filters.add(filterBuilder);
|
|
return this;
|
|
}
|
|
|
|
/**
|
|
* Sets the filter name for the filter that can be used when searching for matched_filters per hit.
|
|
*/
|
|
public AndQueryBuilder queryName(String queryName) {
|
|
this.queryName = queryName;
|
|
return this;
|
|
}
|
|
|
|
@Override
|
|
protected void doXContent(XContentBuilder builder, Params params) throws IOException {
|
|
builder.startObject(AndQueryParser.NAME);
|
|
builder.startArray("filters");
|
|
for (QueryBuilder filter : filters) {
|
|
filter.toXContent(builder, params);
|
|
}
|
|
builder.endArray();
|
|
if (queryName != null) {
|
|
builder.field("_name", queryName);
|
|
}
|
|
builder.endObject();
|
|
}
|
|
} |