Aggs: Remove limitation on field access within aggs to the types

provided in the search

Currently, doing a field lookup within a terms agg will restrict the
fields available to those within the types passed into the search
request.  However, when doing sub aggs within a children agg, the
fields available should not be restricted to those of the search.

This change makes the field lookup use the index level mapper service.
This commit is contained in:
Ryan Ernst 2015-01-29 10:46:09 -08:00
parent 878e46d7f9
commit 4e0e5e7328
2 changed files with 3 additions and 3 deletions

View File

@ -152,7 +152,7 @@ public class ValuesSourceParser<VS extends ValuesSource> {
return config; return config;
} }
FieldMapper<?> mapper = context.smartNameFieldMapper(input.field); FieldMapper<?> mapper = context.mapperService().smartNameFieldMapper(input.field);
if (mapper == null) { if (mapper == null) {
Class<VS> valuesSourceType = valueType != null ? (Class<VS>) valueType.getValuesSourceType() : this.valuesSourceType; Class<VS> valuesSourceType = valueType != null ? (Class<VS>) valueType.getValuesSourceType() : this.valuesSourceType;
ValuesSourceConfig<VS> config = new ValuesSourceConfig<>(valuesSourceType); ValuesSourceConfig<VS> config = new ValuesSourceConfig<>(valuesSourceType);

View File

@ -310,8 +310,8 @@ public class ChildrenTests extends ElasticsearchIntegrationTest {
.setQuery(hasChildQuery(childType, termQuery("color", "orange"))) .setQuery(hasChildQuery(childType, termQuery("color", "orange")))
.addAggregation(children("my-refinements") .addAggregation(children("my-refinements")
.childType(childType) .childType(childType)
.subAggregation(terms("my-colors").field(childType + ".color")) .subAggregation(terms("my-colors").field("color"))
.subAggregation(terms("my-sizes").field(childType + ".size")) .subAggregation(terms("my-sizes").field("size"))
).get(); ).get();
assertNoFailures(response); assertNoFailures(response);
assertHitCount(response, 1); assertHitCount(response, 1);