summaryrefslogtreecommitdiff
path: root/core/src/main/java/org/elasticsearch/search/aggregations/metrics
diff options
context:
space:
mode:
authorChristoph Büscher <christoph@elastic.co>2017-04-18 17:32:09 +0200
committerChristoph Büscher <christoph@elastic.co>2017-04-18 17:38:44 +0200
commit75fdc9449fd1d544cb56ae7e101f6ce323fc331d (patch)
tree644c70ac56a82c9bfd4c670d5e4b5a0502eb9bc2 /core/src/main/java/org/elasticsearch/search/aggregations/metrics
parentc1ba6997ff64008e8a843fda77905a54ff33bcec (diff)
Adding parsing for InternalMax and InternalMin
Diffstat (limited to 'core/src/main/java/org/elasticsearch/search/aggregations/metrics')
-rw-r--r--core/src/main/java/org/elasticsearch/search/aggregations/metrics/ParsedSingleValueNumericMetricsAggregation.java72
-rw-r--r--core/src/main/java/org/elasticsearch/search/aggregations/metrics/cardinality/ParsedCardinality.java2
-rw-r--r--core/src/main/java/org/elasticsearch/search/aggregations/metrics/max/ParsedMax.java62
-rw-r--r--core/src/main/java/org/elasticsearch/search/aggregations/metrics/min/ParsedMin.java62
-rw-r--r--core/src/main/java/org/elasticsearch/search/aggregations/metrics/percentiles/AbstractParsedPercentiles.java2
5 files changed, 198 insertions, 2 deletions
diff --git a/core/src/main/java/org/elasticsearch/search/aggregations/metrics/ParsedSingleValueNumericMetricsAggregation.java b/core/src/main/java/org/elasticsearch/search/aggregations/metrics/ParsedSingleValueNumericMetricsAggregation.java
new file mode 100644
index 0000000000..11da4c09f5
--- /dev/null
+++ b/core/src/main/java/org/elasticsearch/search/aggregations/metrics/ParsedSingleValueNumericMetricsAggregation.java
@@ -0,0 +1,72 @@
+/*
+ * 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.search.aggregations.metrics;
+
+import org.elasticsearch.common.xcontent.ObjectParser;
+import org.elasticsearch.common.xcontent.ObjectParser.ValueType;
+import org.elasticsearch.common.xcontent.XContentParser;
+import org.elasticsearch.common.xcontent.XContentParser.Token;
+import org.elasticsearch.search.aggregations.ParsedAggregation;
+
+import java.io.IOException;
+
+public abstract class ParsedSingleValueNumericMetricsAggregation extends ParsedAggregation implements NumericMetricsAggregation.SingleValue {
+
+ protected double value;
+ protected String valueAsString;
+
+ @Override
+ public String getValueAsString() {
+ if (valueAsString != null) {
+ return valueAsString;
+ } else {
+ return Double.toString(value);
+ }
+ }
+
+ @Override
+ public double value() {
+ return value;
+ }
+
+ protected void setValue(double value) {
+ this.value = value;
+ }
+
+ protected void setValueAsString(String valueAsString) {
+ this.valueAsString = valueAsString;
+ }
+
+ protected static double parseValue(XContentParser parser, double defaultNullValue) throws IOException {
+ Token currentToken = parser.currentToken();
+ if (currentToken == XContentParser.Token.VALUE_NUMBER || currentToken == XContentParser.Token.VALUE_STRING) {
+ return parser.doubleValue();
+ } else {
+ return defaultNullValue;
+ }
+ }
+
+ protected static void declareSingeValueFields(ObjectParser<? extends ParsedSingleValueNumericMetricsAggregation, Void> objectParser,
+ double defaultNullValue) {
+ declareAggregationFields(objectParser);
+ objectParser.declareField(ParsedSingleValueNumericMetricsAggregation::setValue,
+ (parser, context) -> parseValue(parser, defaultNullValue), CommonFields.VALUE, ValueType.DOUBLE_OR_NULL);
+ objectParser.declareString(ParsedSingleValueNumericMetricsAggregation::setValueAsString, CommonFields.VALUE_AS_STRING);
+ }
+}
diff --git a/core/src/main/java/org/elasticsearch/search/aggregations/metrics/cardinality/ParsedCardinality.java b/core/src/main/java/org/elasticsearch/search/aggregations/metrics/cardinality/ParsedCardinality.java
index cac367cc7a..5c7a1bad42 100644
--- a/core/src/main/java/org/elasticsearch/search/aggregations/metrics/cardinality/ParsedCardinality.java
+++ b/core/src/main/java/org/elasticsearch/search/aggregations/metrics/cardinality/ParsedCardinality.java
@@ -62,7 +62,7 @@ public class ParsedCardinality extends ParsedAggregation implements Cardinality
CardinalityAggregationBuilder.NAME, true, ParsedCardinality::new);
static {
- declareCommonFields(PARSER);
+ declareAggregationFields(PARSER);
PARSER.declareLong(ParsedCardinality::setValue, CommonFields.VALUE);
}
diff --git a/core/src/main/java/org/elasticsearch/search/aggregations/metrics/max/ParsedMax.java b/core/src/main/java/org/elasticsearch/search/aggregations/metrics/max/ParsedMax.java
new file mode 100644
index 0000000000..f3a4ff85f8
--- /dev/null
+++ b/core/src/main/java/org/elasticsearch/search/aggregations/metrics/max/ParsedMax.java
@@ -0,0 +1,62 @@
+/*
+ * 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.search.aggregations.metrics.max;
+
+import org.elasticsearch.common.xcontent.ObjectParser;
+import org.elasticsearch.common.xcontent.XContentBuilder;
+import org.elasticsearch.common.xcontent.XContentParser;
+import org.elasticsearch.search.aggregations.metrics.ParsedSingleValueNumericMetricsAggregation;
+
+import java.io.IOException;
+
+public class ParsedMax extends ParsedSingleValueNumericMetricsAggregation implements Max {
+
+ @Override
+ public double getValue() {
+ return value();
+ }
+
+ @Override
+ protected String getType() {
+ return MaxAggregationBuilder.NAME;
+ }
+
+ @Override
+ protected XContentBuilder doXContentBody(XContentBuilder builder, Params params) throws IOException {
+ boolean hasValue = !Double.isInfinite(value);
+ builder.field(CommonFields.VALUE.getPreferredName(), hasValue ? value : null);
+ if (hasValue && valueAsString != null) {
+ builder.field(CommonFields.VALUE_AS_STRING.getPreferredName(), valueAsString);
+ }
+ return builder;
+ }
+
+ private static final ObjectParser<ParsedMax, Void> PARSER = new ObjectParser<>(ParsedMax.class.getSimpleName(), true, ParsedMax::new);
+
+ static {
+ declareSingeValueFields(PARSER, Double.NEGATIVE_INFINITY);
+ }
+
+ public static ParsedMax fromXContent(XContentParser parser, final String name) {
+ ParsedMax max = PARSER.apply(parser, null);
+ max.setName(name);
+ return max;
+ }
+} \ No newline at end of file
diff --git a/core/src/main/java/org/elasticsearch/search/aggregations/metrics/min/ParsedMin.java b/core/src/main/java/org/elasticsearch/search/aggregations/metrics/min/ParsedMin.java
new file mode 100644
index 0000000000..5be0444e47
--- /dev/null
+++ b/core/src/main/java/org/elasticsearch/search/aggregations/metrics/min/ParsedMin.java
@@ -0,0 +1,62 @@
+/*
+ * 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.search.aggregations.metrics.min;
+
+import org.elasticsearch.common.xcontent.ObjectParser;
+import org.elasticsearch.common.xcontent.XContentBuilder;
+import org.elasticsearch.common.xcontent.XContentParser;
+import org.elasticsearch.search.aggregations.metrics.ParsedSingleValueNumericMetricsAggregation;
+
+import java.io.IOException;
+
+public class ParsedMin extends ParsedSingleValueNumericMetricsAggregation implements Min {
+
+ @Override
+ public double getValue() {
+ return value();
+ }
+
+ @Override
+ protected String getType() {
+ return MinAggregationBuilder.NAME;
+ }
+
+ @Override
+ protected XContentBuilder doXContentBody(XContentBuilder builder, Params params) throws IOException {
+ boolean hasValue = !Double.isInfinite(value);
+ builder.field(CommonFields.VALUE.getPreferredName(), hasValue ? value : null);
+ if (hasValue && valueAsString != null) {
+ builder.field(CommonFields.VALUE_AS_STRING.getPreferredName(), valueAsString);
+ }
+ return builder;
+ }
+
+ private static final ObjectParser<ParsedMin, Void> PARSER = new ObjectParser<>(ParsedMin.class.getSimpleName(), true, ParsedMin::new);
+
+ static {
+ declareSingeValueFields(PARSER, Double.POSITIVE_INFINITY);
+ }
+
+ public static ParsedMin fromXContent(XContentParser parser, final String name) {
+ ParsedMin min = PARSER.apply(parser, null);
+ min.setName(name);
+ return min;
+ }
+} \ No newline at end of file
diff --git a/core/src/main/java/org/elasticsearch/search/aggregations/metrics/percentiles/AbstractParsedPercentiles.java b/core/src/main/java/org/elasticsearch/search/aggregations/metrics/percentiles/AbstractParsedPercentiles.java
index a45d089cc7..e3152bac3a 100644
--- a/core/src/main/java/org/elasticsearch/search/aggregations/metrics/percentiles/AbstractParsedPercentiles.java
+++ b/core/src/main/java/org/elasticsearch/search/aggregations/metrics/percentiles/AbstractParsedPercentiles.java
@@ -120,7 +120,7 @@ public abstract class AbstractParsedPercentiles extends ParsedAggregation implem
}
protected static void declarePercentilesFields(ObjectParser<? extends AbstractParsedPercentiles, Void> objectParser) {
- ParsedAggregation.declareCommonFields(objectParser);
+ ParsedAggregation.declareAggregationFields(objectParser);
objectParser.declareField((parser, aggregation, context) -> {
XContentParser.Token token = parser.currentToken();