/* * Copyright 2018-2023 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 com.amazonaws.services.lookoutmetrics.model; import java.io.Serializable; import javax.annotation.Generated; import com.amazonaws.protocol.StructuredPojo; import com.amazonaws.protocol.ProtocolMarshaller; /** *
* A calculation made by contrasting a measure and a dimension from your source data. *
* * @see AWS API * Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class Metric implements Serializable, Cloneable, StructuredPojo { /** ** The name of the metric. *
*/ private String metricName; /** ** The function with which the metric is calculated. *
*/ private String aggregationFunction; /** ** The namespace for the metric. *
*/ private String namespace; /** ** The name of the metric. *
* * @param metricName * The name of the metric. */ public void setMetricName(String metricName) { this.metricName = metricName; } /** ** The name of the metric. *
* * @return The name of the metric. */ public String getMetricName() { return this.metricName; } /** ** The name of the metric. *
* * @param metricName * The name of the metric. * @return Returns a reference to this object so that method calls can be chained together. */ public Metric withMetricName(String metricName) { setMetricName(metricName); return this; } /** ** The function with which the metric is calculated. *
* * @param aggregationFunction * The function with which the metric is calculated. * @see AggregationFunction */ public void setAggregationFunction(String aggregationFunction) { this.aggregationFunction = aggregationFunction; } /** ** The function with which the metric is calculated. *
* * @return The function with which the metric is calculated. * @see AggregationFunction */ public String getAggregationFunction() { return this.aggregationFunction; } /** ** The function with which the metric is calculated. *
* * @param aggregationFunction * The function with which the metric is calculated. * @return Returns a reference to this object so that method calls can be chained together. * @see AggregationFunction */ public Metric withAggregationFunction(String aggregationFunction) { setAggregationFunction(aggregationFunction); return this; } /** ** The function with which the metric is calculated. *
* * @param aggregationFunction * The function with which the metric is calculated. * @return Returns a reference to this object so that method calls can be chained together. * @see AggregationFunction */ public Metric withAggregationFunction(AggregationFunction aggregationFunction) { this.aggregationFunction = aggregationFunction.toString(); return this; } /** ** The namespace for the metric. *
* * @param namespace * The namespace for the metric. */ public void setNamespace(String namespace) { this.namespace = namespace; } /** ** The namespace for the metric. *
* * @return The namespace for the metric. */ public String getNamespace() { return this.namespace; } /** ** The namespace for the metric. *
* * @param namespace * The namespace for the metric. * @return Returns a reference to this object so that method calls can be chained together. */ public Metric withNamespace(String namespace) { setNamespace(namespace); return this; } /** * 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. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getMetricName() != null) sb.append("MetricName: ").append(getMetricName()).append(","); if (getAggregationFunction() != null) sb.append("AggregationFunction: ").append(getAggregationFunction()).append(","); if (getNamespace() != null) sb.append("Namespace: ").append(getNamespace()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof Metric == false) return false; Metric other = (Metric) obj; if (other.getMetricName() == null ^ this.getMetricName() == null) return false; if (other.getMetricName() != null && other.getMetricName().equals(this.getMetricName()) == false) return false; if (other.getAggregationFunction() == null ^ this.getAggregationFunction() == null) return false; if (other.getAggregationFunction() != null && other.getAggregationFunction().equals(this.getAggregationFunction()) == false) return false; if (other.getNamespace() == null ^ this.getNamespace() == null) return false; if (other.getNamespace() != null && other.getNamespace().equals(this.getNamespace()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getMetricName() == null) ? 0 : getMetricName().hashCode()); hashCode = prime * hashCode + ((getAggregationFunction() == null) ? 0 : getAggregationFunction().hashCode()); hashCode = prime * hashCode + ((getNamespace() == null) ? 0 : getNamespace().hashCode()); return hashCode; } @Override public Metric clone() { try { return (Metric) super.clone(); } catch (CloneNotSupportedException e) { throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e); } } @com.amazonaws.annotation.SdkInternalApi @Override public void marshall(ProtocolMarshaller protocolMarshaller) { com.amazonaws.services.lookoutmetrics.model.transform.MetricMarshaller.getInstance().marshall(this, protocolMarshaller); } }