All Downloads are FREE. Search and download functionalities are using the official Maven repository.

software.amazon.awssdk.services.cloudwatch.model.InsightRuleMetricDatapoint Maven / Gradle / Ivy

Go to download

The AWS Java SDK for Amazon CloudWatch module holds the client classes that are used for communicating with Amazon CloudWatch Service

There is a newer version: 2.30.2
Show newest version
/*
 * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
 * the License. A copy of the License is located at
 * 
 * http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file 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 software.amazon.awssdk.services.cloudwatch.model;

import java.io.Serializable;
import java.time.Instant;
import java.util.Arrays;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.Optional;
import java.util.function.BiConsumer;
import java.util.function.Function;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.core.SdkField;
import software.amazon.awssdk.core.SdkPojo;
import software.amazon.awssdk.core.protocol.MarshallLocation;
import software.amazon.awssdk.core.protocol.MarshallingType;
import software.amazon.awssdk.core.traits.LocationTrait;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;

/**
 * 

* One data point from the metric time series returned in a Contributor Insights rule report. *

*

* For more information, see GetInsightRuleReport. *

*/ @Generated("software.amazon.awssdk:codegen") public final class InsightRuleMetricDatapoint implements SdkPojo, Serializable, ToCopyableBuilder { private static final SdkField TIMESTAMP_FIELD = SdkField. builder(MarshallingType.INSTANT) .memberName("Timestamp").getter(getter(InsightRuleMetricDatapoint::timestamp)).setter(setter(Builder::timestamp)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Timestamp").build()).build(); private static final SdkField UNIQUE_CONTRIBUTORS_FIELD = SdkField. builder(MarshallingType.DOUBLE) .memberName("UniqueContributors").getter(getter(InsightRuleMetricDatapoint::uniqueContributors)) .setter(setter(Builder::uniqueContributors)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("UniqueContributors").build()) .build(); private static final SdkField MAX_CONTRIBUTOR_VALUE_FIELD = SdkField. builder(MarshallingType.DOUBLE) .memberName("MaxContributorValue").getter(getter(InsightRuleMetricDatapoint::maxContributorValue)) .setter(setter(Builder::maxContributorValue)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("MaxContributorValue").build()) .build(); private static final SdkField SAMPLE_COUNT_FIELD = SdkField. builder(MarshallingType.DOUBLE) .memberName("SampleCount").getter(getter(InsightRuleMetricDatapoint::sampleCount)) .setter(setter(Builder::sampleCount)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("SampleCount").build()).build(); private static final SdkField AVERAGE_FIELD = SdkField. builder(MarshallingType.DOUBLE).memberName("Average") .getter(getter(InsightRuleMetricDatapoint::average)).setter(setter(Builder::average)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Average").build()).build(); private static final SdkField SUM_FIELD = SdkField. builder(MarshallingType.DOUBLE).memberName("Sum") .getter(getter(InsightRuleMetricDatapoint::sum)).setter(setter(Builder::sum)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Sum").build()).build(); private static final SdkField MINIMUM_FIELD = SdkField. builder(MarshallingType.DOUBLE).memberName("Minimum") .getter(getter(InsightRuleMetricDatapoint::minimum)).setter(setter(Builder::minimum)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Minimum").build()).build(); private static final SdkField MAXIMUM_FIELD = SdkField. builder(MarshallingType.DOUBLE).memberName("Maximum") .getter(getter(InsightRuleMetricDatapoint::maximum)).setter(setter(Builder::maximum)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Maximum").build()).build(); private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(TIMESTAMP_FIELD, UNIQUE_CONTRIBUTORS_FIELD, MAX_CONTRIBUTOR_VALUE_FIELD, SAMPLE_COUNT_FIELD, AVERAGE_FIELD, SUM_FIELD, MINIMUM_FIELD, MAXIMUM_FIELD)); private static final Map> SDK_NAME_TO_FIELD = Collections .unmodifiableMap(new HashMap>() { { put("Timestamp", TIMESTAMP_FIELD); put("UniqueContributors", UNIQUE_CONTRIBUTORS_FIELD); put("MaxContributorValue", MAX_CONTRIBUTOR_VALUE_FIELD); put("SampleCount", SAMPLE_COUNT_FIELD); put("Average", AVERAGE_FIELD); put("Sum", SUM_FIELD); put("Minimum", MINIMUM_FIELD); put("Maximum", MAXIMUM_FIELD); } }); private static final long serialVersionUID = 1L; private final Instant timestamp; private final Double uniqueContributors; private final Double maxContributorValue; private final Double sampleCount; private final Double average; private final Double sum; private final Double minimum; private final Double maximum; private InsightRuleMetricDatapoint(BuilderImpl builder) { this.timestamp = builder.timestamp; this.uniqueContributors = builder.uniqueContributors; this.maxContributorValue = builder.maxContributorValue; this.sampleCount = builder.sampleCount; this.average = builder.average; this.sum = builder.sum; this.minimum = builder.minimum; this.maximum = builder.maximum; } /** *

* The timestamp of the data point. *

* * @return The timestamp of the data point. */ public final Instant timestamp() { return timestamp; } /** *

* The number of unique contributors who published data during this timestamp. *

*

* This statistic is returned only if you included it in the Metrics array in your request. *

* * @return The number of unique contributors who published data during this timestamp.

*

* This statistic is returned only if you included it in the Metrics array in your request. */ public final Double uniqueContributors() { return uniqueContributors; } /** *

* The maximum value provided by one contributor during this timestamp. Each timestamp is evaluated separately, so * the identity of the max contributor could be different for each timestamp. *

*

* This statistic is returned only if you included it in the Metrics array in your request. *

* * @return The maximum value provided by one contributor during this timestamp. Each timestamp is evaluated * separately, so the identity of the max contributor could be different for each timestamp.

*

* This statistic is returned only if you included it in the Metrics array in your request. */ public final Double maxContributorValue() { return maxContributorValue; } /** *

* The number of occurrences that matched the rule during this data point. *

*

* This statistic is returned only if you included it in the Metrics array in your request. *

* * @return The number of occurrences that matched the rule during this data point.

*

* This statistic is returned only if you included it in the Metrics array in your request. */ public final Double sampleCount() { return sampleCount; } /** *

* The average value from all contributors during the time period represented by that data point. *

*

* This statistic is returned only if you included it in the Metrics array in your request. *

* * @return The average value from all contributors during the time period represented by that data point.

*

* This statistic is returned only if you included it in the Metrics array in your request. */ public final Double average() { return average; } /** *

* The sum of the values from all contributors during the time period represented by that data point. *

*

* This statistic is returned only if you included it in the Metrics array in your request. *

* * @return The sum of the values from all contributors during the time period represented by that data point.

*

* This statistic is returned only if you included it in the Metrics array in your request. */ public final Double sum() { return sum; } /** *

* The minimum value from a single contributor during the time period represented by that data point. *

*

* This statistic is returned only if you included it in the Metrics array in your request. *

* * @return The minimum value from a single contributor during the time period represented by that data point.

*

* This statistic is returned only if you included it in the Metrics array in your request. */ public final Double minimum() { return minimum; } /** *

* The maximum value from a single occurence from a single contributor during the time period represented by that * data point. *

*

* This statistic is returned only if you included it in the Metrics array in your request. *

* * @return The maximum value from a single occurence from a single contributor during the time period represented by * that data point.

*

* This statistic is returned only if you included it in the Metrics array in your request. */ public final Double maximum() { return maximum; } @Override public Builder toBuilder() { return new BuilderImpl(this); } public static Builder builder() { return new BuilderImpl(); } public static Class serializableBuilderClass() { return BuilderImpl.class; } @Override public final int hashCode() { int hashCode = 1; hashCode = 31 * hashCode + Objects.hashCode(timestamp()); hashCode = 31 * hashCode + Objects.hashCode(uniqueContributors()); hashCode = 31 * hashCode + Objects.hashCode(maxContributorValue()); hashCode = 31 * hashCode + Objects.hashCode(sampleCount()); hashCode = 31 * hashCode + Objects.hashCode(average()); hashCode = 31 * hashCode + Objects.hashCode(sum()); hashCode = 31 * hashCode + Objects.hashCode(minimum()); hashCode = 31 * hashCode + Objects.hashCode(maximum()); return hashCode; } @Override public final boolean equals(Object obj) { return equalsBySdkFields(obj); } @Override public final boolean equalsBySdkFields(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (!(obj instanceof InsightRuleMetricDatapoint)) { return false; } InsightRuleMetricDatapoint other = (InsightRuleMetricDatapoint) obj; return Objects.equals(timestamp(), other.timestamp()) && Objects.equals(uniqueContributors(), other.uniqueContributors()) && Objects.equals(maxContributorValue(), other.maxContributorValue()) && Objects.equals(sampleCount(), other.sampleCount()) && Objects.equals(average(), other.average()) && Objects.equals(sum(), other.sum()) && Objects.equals(minimum(), other.minimum()) && Objects.equals(maximum(), other.maximum()); } /** * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be * redacted from this string using a placeholder value. */ @Override public final String toString() { return ToString.builder("InsightRuleMetricDatapoint").add("Timestamp", timestamp()) .add("UniqueContributors", uniqueContributors()).add("MaxContributorValue", maxContributorValue()) .add("SampleCount", sampleCount()).add("Average", average()).add("Sum", sum()).add("Minimum", minimum()) .add("Maximum", maximum()).build(); } public final Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "Timestamp": return Optional.ofNullable(clazz.cast(timestamp())); case "UniqueContributors": return Optional.ofNullable(clazz.cast(uniqueContributors())); case "MaxContributorValue": return Optional.ofNullable(clazz.cast(maxContributorValue())); case "SampleCount": return Optional.ofNullable(clazz.cast(sampleCount())); case "Average": return Optional.ofNullable(clazz.cast(average())); case "Sum": return Optional.ofNullable(clazz.cast(sum())); case "Minimum": return Optional.ofNullable(clazz.cast(minimum())); case "Maximum": return Optional.ofNullable(clazz.cast(maximum())); default: return Optional.empty(); } } @Override public final List> sdkFields() { return SDK_FIELDS; } @Override public final Map> sdkFieldNameToField() { return SDK_NAME_TO_FIELD; } private static Function getter(Function g) { return obj -> g.apply((InsightRuleMetricDatapoint) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends SdkPojo, CopyableBuilder { /** *

* The timestamp of the data point. *

* * @param timestamp * The timestamp of the data point. * @return Returns a reference to this object so that method calls can be chained together. */ Builder timestamp(Instant timestamp); /** *

* The number of unique contributors who published data during this timestamp. *

*

* This statistic is returned only if you included it in the Metrics array in your request. *

* * @param uniqueContributors * The number of unique contributors who published data during this timestamp.

*

* This statistic is returned only if you included it in the Metrics array in your request. * @return Returns a reference to this object so that method calls can be chained together. */ Builder uniqueContributors(Double uniqueContributors); /** *

* The maximum value provided by one contributor during this timestamp. Each timestamp is evaluated separately, * so the identity of the max contributor could be different for each timestamp. *

*

* This statistic is returned only if you included it in the Metrics array in your request. *

* * @param maxContributorValue * The maximum value provided by one contributor during this timestamp. Each timestamp is evaluated * separately, so the identity of the max contributor could be different for each timestamp.

*

* This statistic is returned only if you included it in the Metrics array in your request. * @return Returns a reference to this object so that method calls can be chained together. */ Builder maxContributorValue(Double maxContributorValue); /** *

* The number of occurrences that matched the rule during this data point. *

*

* This statistic is returned only if you included it in the Metrics array in your request. *

* * @param sampleCount * The number of occurrences that matched the rule during this data point.

*

* This statistic is returned only if you included it in the Metrics array in your request. * @return Returns a reference to this object so that method calls can be chained together. */ Builder sampleCount(Double sampleCount); /** *

* The average value from all contributors during the time period represented by that data point. *

*

* This statistic is returned only if you included it in the Metrics array in your request. *

* * @param average * The average value from all contributors during the time period represented by that data point.

*

* This statistic is returned only if you included it in the Metrics array in your request. * @return Returns a reference to this object so that method calls can be chained together. */ Builder average(Double average); /** *

* The sum of the values from all contributors during the time period represented by that data point. *

*

* This statistic is returned only if you included it in the Metrics array in your request. *

* * @param sum * The sum of the values from all contributors during the time period represented by that data point.

*

* This statistic is returned only if you included it in the Metrics array in your request. * @return Returns a reference to this object so that method calls can be chained together. */ Builder sum(Double sum); /** *

* The minimum value from a single contributor during the time period represented by that data point. *

*

* This statistic is returned only if you included it in the Metrics array in your request. *

* * @param minimum * The minimum value from a single contributor during the time period represented by that data point.

*

* This statistic is returned only if you included it in the Metrics array in your request. * @return Returns a reference to this object so that method calls can be chained together. */ Builder minimum(Double minimum); /** *

* The maximum value from a single occurence from a single contributor during the time period represented by * that data point. *

*

* This statistic is returned only if you included it in the Metrics array in your request. *

* * @param maximum * The maximum value from a single occurence from a single contributor during the time period represented * by that data point.

*

* This statistic is returned only if you included it in the Metrics array in your request. * @return Returns a reference to this object so that method calls can be chained together. */ Builder maximum(Double maximum); } static final class BuilderImpl implements Builder { private Instant timestamp; private Double uniqueContributors; private Double maxContributorValue; private Double sampleCount; private Double average; private Double sum; private Double minimum; private Double maximum; private BuilderImpl() { } private BuilderImpl(InsightRuleMetricDatapoint model) { timestamp(model.timestamp); uniqueContributors(model.uniqueContributors); maxContributorValue(model.maxContributorValue); sampleCount(model.sampleCount); average(model.average); sum(model.sum); minimum(model.minimum); maximum(model.maximum); } public final Instant getTimestamp() { return timestamp; } public final void setTimestamp(Instant timestamp) { this.timestamp = timestamp; } @Override public final Builder timestamp(Instant timestamp) { this.timestamp = timestamp; return this; } public final Double getUniqueContributors() { return uniqueContributors; } public final void setUniqueContributors(Double uniqueContributors) { this.uniqueContributors = uniqueContributors; } @Override public final Builder uniqueContributors(Double uniqueContributors) { this.uniqueContributors = uniqueContributors; return this; } public final Double getMaxContributorValue() { return maxContributorValue; } public final void setMaxContributorValue(Double maxContributorValue) { this.maxContributorValue = maxContributorValue; } @Override public final Builder maxContributorValue(Double maxContributorValue) { this.maxContributorValue = maxContributorValue; return this; } public final Double getSampleCount() { return sampleCount; } public final void setSampleCount(Double sampleCount) { this.sampleCount = sampleCount; } @Override public final Builder sampleCount(Double sampleCount) { this.sampleCount = sampleCount; return this; } public final Double getAverage() { return average; } public final void setAverage(Double average) { this.average = average; } @Override public final Builder average(Double average) { this.average = average; return this; } public final Double getSum() { return sum; } public final void setSum(Double sum) { this.sum = sum; } @Override public final Builder sum(Double sum) { this.sum = sum; return this; } public final Double getMinimum() { return minimum; } public final void setMinimum(Double minimum) { this.minimum = minimum; } @Override public final Builder minimum(Double minimum) { this.minimum = minimum; return this; } public final Double getMaximum() { return maximum; } public final void setMaximum(Double maximum) { this.maximum = maximum; } @Override public final Builder maximum(Double maximum) { this.maximum = maximum; return this; } @Override public InsightRuleMetricDatapoint build() { return new InsightRuleMetricDatapoint(this); } @Override public List> sdkFields() { return SDK_FIELDS; } @Override public Map> sdkFieldNameToField() { return SDK_NAME_TO_FIELD; } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy