Class AdaptingAggregator
java.lang.Object
org.elasticsearch.search.aggregations.BucketCollector
org.elasticsearch.search.aggregations.Aggregator
org.elasticsearch.search.aggregations.AdaptingAggregator
- All Implemented Interfaces:
Closeable
,AutoCloseable
,org.apache.lucene.search.Collector
,org.elasticsearch.core.Releasable
- Direct Known Subclasses:
StringTermsAggregatorFromFilters
An Aggregator that delegates collection to another
Aggregator and then translates its results into the results
you'd expect from another aggregation.
-
Nested Class Summary
Nested classes/interfaces inherited from class org.elasticsearch.search.aggregations.Aggregator
Aggregator.BucketComparator, Aggregator.Parser, Aggregator.SubAggCollectionMode
-
Field Summary
Fields inherited from class org.elasticsearch.search.aggregations.BucketCollector
NO_OP_COLLECTOR
-
Constructor Summary
ConstructorDescriptionAdaptingAggregator(Aggregator parent, AggregatorFactories subAggregators, org.elasticsearch.core.CheckedFunction<AggregatorFactories,? extends Aggregator,IOException> delegate)
-
Method Summary
Modifier and TypeMethodDescriptionprotected abstract InternalAggregation
adapt(InternalAggregation delegateResult)
Adapt the result from the collecting Aggregator into the result expected by this Aggregator.buildAggregations(long[] owningBucketOrds)
Build the results of this aggregation.Build an empty aggregation.void
close()
void
Collect debug information to add to the profiling results.delegate()
getLeafCollector(org.apache.lucene.index.LeafReaderContext ctx)
name()
Return the name of this aggregator.parent()
Return the parent aggregator.void
Post-collection callback.void
Pre collection callback.org.apache.lucene.search.ScoreMode
subAggregator(String name)
Return the sub aggregator with the provided name.Get the aggregators running under this one.Methods inherited from class org.elasticsearch.search.aggregations.Aggregator
bucketComparator, buildTopLevel, resolveSortPath, resolveSortPathOnValidAgg
-
Constructor Details
-
AdaptingAggregator
public AdaptingAggregator(Aggregator parent, AggregatorFactories subAggregators, org.elasticsearch.core.CheckedFunction<AggregatorFactories,? extends Aggregator,IOException> delegate) throws IOException- Throws:
IOException
-
-
Method Details
-
adapt
Adapt the result from the collecting Aggregator into the result expected by this Aggregator.- Throws:
IOException
-
close
public final void close() -
scoreMode
public final org.apache.lucene.search.ScoreMode scoreMode() -
name
Description copied from class:Aggregator
Return the name of this aggregator.- Specified by:
name
in classAggregator
-
parent
Description copied from class:Aggregator
Return the parent aggregator.- Specified by:
parent
in classAggregator
-
subAggregator
Description copied from class:Aggregator
Return the sub aggregator with the provided name.- Specified by:
subAggregator
in classAggregator
-
getLeafCollector
public final LeafBucketCollector getLeafCollector(org.apache.lucene.index.LeafReaderContext ctx) throws IOException- Specified by:
getLeafCollector
in interfaceorg.apache.lucene.search.Collector
- Specified by:
getLeafCollector
in classBucketCollector
- Throws:
IOException
-
preCollection
Description copied from class:BucketCollector
Pre collection callback.- Specified by:
preCollection
in classBucketCollector
- Throws:
IOException
-
postCollection
Description copied from class:BucketCollector
Post-collection callback.- Specified by:
postCollection
in classBucketCollector
- Throws:
IOException
-
buildAggregations
Description copied from class:Aggregator
Build the results of this aggregation.- Specified by:
buildAggregations
in classAggregator
- Parameters:
owningBucketOrds
- the ordinals of the buckets that we want to collect from this aggregation- Returns:
- the results for each ordinal, in the same order as the array of ordinals
- Throws:
IOException
-
buildEmptyAggregation
Description copied from class:Aggregator
Build an empty aggregation.- Specified by:
buildEmptyAggregation
in classAggregator
-
subAggregators
Description copied from class:Aggregator
Get the aggregators running under this one.- Specified by:
subAggregators
in classAggregator
-
collectDebugInfo
Description copied from class:Aggregator
Collect debug information to add to the profiling results. This will only be called if the aggregation is being profiled.Well behaved implementations will always call the superclass implementation just in case it has something interesting. They will also only add objects which can be serialized with
StreamOutput.writeGenericValue(Object)
andXContentBuilder.value(Object)
. And they'll have an integration test.- Overrides:
collectDebugInfo
in classAggregator
-
delegate
-