/* * Copyright 2010-2019 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.logs.model; import java.io.Serializable; /** *
* Indicates how to transform ingested log events in to metric data in a * CloudWatch metric. *
*/ public class MetricTransformation implements Serializable { /** ** The name of the CloudWatch metric. *
*
* Constraints:
* Length: - 255
* Pattern: [^:*$]*
*/
private String metricName;
/**
*
* The namespace of the CloudWatch metric. *
*
* Constraints:
* Length: - 255
* Pattern: [^:*$]*
*/
private String metricNamespace;
/**
*
* The value to publish to the CloudWatch metric when a filter pattern * matches a log event. *
*
* Constraints:
* Length: - 100
*/
private String metricValue;
/**
*
* (Optional) The value to emit when a filter pattern does not match a log * event. This value can be null. *
*/ private Double defaultValue; /** ** The name of the CloudWatch metric. *
*
* Constraints:
* Length: - 255
* Pattern: [^:*$]*
*
* @return
* The name of the CloudWatch metric. *
*/ public String getMetricName() { return metricName; } /** ** The name of the CloudWatch metric. *
*
* Constraints:
* Length: - 255
* Pattern: [^:*$]*
*
* @param metricName
* The name of the CloudWatch metric. *
*/ public void setMetricName(String metricName) { this.metricName = metricName; } /** ** The name of the CloudWatch metric. *
** Returns a reference to this object so that method calls can be chained * together. *
* Constraints:
* Length: - 255
* Pattern: [^:*$]*
*
* @param metricName
* The name of the CloudWatch metric. *
* @return A reference to this updated object so that method calls can be * chained together. */ public MetricTransformation withMetricName(String metricName) { this.metricName = metricName; return this; } /** ** The namespace of the CloudWatch metric. *
*
* Constraints:
* Length: - 255
* Pattern: [^:*$]*
*
* @return
* The namespace of the CloudWatch metric. *
*/ public String getMetricNamespace() { return metricNamespace; } /** ** The namespace of the CloudWatch metric. *
*
* Constraints:
* Length: - 255
* Pattern: [^:*$]*
*
* @param metricNamespace
* The namespace of the CloudWatch metric. *
*/ public void setMetricNamespace(String metricNamespace) { this.metricNamespace = metricNamespace; } /** ** The namespace of the CloudWatch metric. *
** Returns a reference to this object so that method calls can be chained * together. *
* Constraints:
* Length: - 255
* Pattern: [^:*$]*
*
* @param metricNamespace
* The namespace of the CloudWatch metric. *
* @return A reference to this updated object so that method calls can be * chained together. */ public MetricTransformation withMetricNamespace(String metricNamespace) { this.metricNamespace = metricNamespace; return this; } /** ** The value to publish to the CloudWatch metric when a filter pattern * matches a log event. *
*
* Constraints:
* Length: - 100
*
* @return
* The value to publish to the CloudWatch metric when a filter * pattern matches a log event. *
*/ public String getMetricValue() { return metricValue; } /** ** The value to publish to the CloudWatch metric when a filter pattern * matches a log event. *
*
* Constraints:
* Length: - 100
*
* @param metricValue
* The value to publish to the CloudWatch metric when a filter * pattern matches a log event. *
*/ public void setMetricValue(String metricValue) { this.metricValue = metricValue; } /** ** The value to publish to the CloudWatch metric when a filter pattern * matches a log event. *
** Returns a reference to this object so that method calls can be chained * together. *
* Constraints:
* Length: - 100
*
* @param metricValue
* The value to publish to the CloudWatch metric when a filter * pattern matches a log event. *
* @return A reference to this updated object so that method calls can be * chained together. */ public MetricTransformation withMetricValue(String metricValue) { this.metricValue = metricValue; return this; } /** ** (Optional) The value to emit when a filter pattern does not match a log * event. This value can be null. *
* * @return* (Optional) The value to emit when a filter pattern does not match * a log event. This value can be null. *
*/ public Double getDefaultValue() { return defaultValue; } /** ** (Optional) The value to emit when a filter pattern does not match a log * event. This value can be null. *
* * @param defaultValue* (Optional) The value to emit when a filter pattern does not * match a log event. This value can be null. *
*/ public void setDefaultValue(Double defaultValue) { this.defaultValue = defaultValue; } /** ** (Optional) The value to emit when a filter pattern does not match a log * event. This value can be null. *
** Returns a reference to this object so that method calls can be chained * together. * * @param defaultValue
* (Optional) The value to emit when a filter pattern does not * match a log event. This value can be null. *
* @return A reference to this updated object so that method calls can be * chained together. */ public MetricTransformation withDefaultValue(Double defaultValue) { this.defaultValue = defaultValue; return this; } /** * Returns a string representation of this object; useful for testing and * debugging. * * @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: " + getMetricName() + ","); if (getMetricNamespace() != null) sb.append("metricNamespace: " + getMetricNamespace() + ","); if (getMetricValue() != null) sb.append("metricValue: " + getMetricValue() + ","); if (getDefaultValue() != null) sb.append("defaultValue: " + getDefaultValue()); sb.append("}"); return sb.toString(); } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getMetricName() == null) ? 0 : getMetricName().hashCode()); hashCode = prime * hashCode + ((getMetricNamespace() == null) ? 0 : getMetricNamespace().hashCode()); hashCode = prime * hashCode + ((getMetricValue() == null) ? 0 : getMetricValue().hashCode()); hashCode = prime * hashCode + ((getDefaultValue() == null) ? 0 : getDefaultValue().hashCode()); return hashCode; } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof MetricTransformation == false) return false; MetricTransformation other = (MetricTransformation) obj; if (other.getMetricName() == null ^ this.getMetricName() == null) return false; if (other.getMetricName() != null && other.getMetricName().equals(this.getMetricName()) == false) return false; if (other.getMetricNamespace() == null ^ this.getMetricNamespace() == null) return false; if (other.getMetricNamespace() != null && other.getMetricNamespace().equals(this.getMetricNamespace()) == false) return false; if (other.getMetricValue() == null ^ this.getMetricValue() == null) return false; if (other.getMetricValue() != null && other.getMetricValue().equals(this.getMetricValue()) == false) return false; if (other.getDefaultValue() == null ^ this.getDefaultValue() == null) return false; if (other.getDefaultValue() != null && other.getDefaultValue().equals(this.getDefaultValue()) == false) return false; return true; } }