org.codelibs.elasticsearch.search.aggregations.PipelineAggregationBuilder Maven / Gradle / Ivy
/*
* 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.codelibs.elasticsearch.search.aggregations;
import org.codelibs.elasticsearch.action.support.ToXContentToBytes;
import org.codelibs.elasticsearch.common.io.stream.NamedWriteable;
import org.codelibs.elasticsearch.search.aggregations.AggregatorFactory;
import org.codelibs.elasticsearch.search.aggregations.pipeline.PipelineAggregator;
import java.io.IOException;
import java.util.List;
import java.util.Map;
/**
* A factory that knows how to create an {PipelineAggregator} of a
* specific type.
*/
public abstract class PipelineAggregationBuilder extends ToXContentToBytes
implements NamedWriteable {
protected final String name;
protected final String[] bucketsPaths;
/**
* Constructs a new pipeline aggregator factory.
*
* @param name
* The aggregation name
*/
protected PipelineAggregationBuilder(String name, String[] bucketsPaths) {
if (name == null) {
throw new IllegalArgumentException("[name] must not be null: [" + name + "]");
}
if (bucketsPaths == null) {
throw new IllegalArgumentException("[bucketsPaths] must not be null: [" + name + "]");
}
this.name = name;
this.bucketsPaths = bucketsPaths;
}
/** Return this aggregation's name. */
public String getName() {
return name;
}
/** Return the consumed buckets paths. */
public final String[] getBucketsPaths() {
return bucketsPaths;
}
/**
* Internal: Validates the state of this factory (makes sure the factory is properly
* configured)
*/
protected abstract void validate(AggregatorFactory> parent, AggregatorFactory>[] factories,
List pipelineAggregatorFactories);
/**
* Creates the pipeline aggregator
*
* @return The created aggregator
*/
protected abstract PipelineAggregator create() throws IOException;
/** Associate metadata with this {PipelineAggregationBuilder}. */
public abstract PipelineAggregationBuilder setMetaData(Map metaData);
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy