com.amazonaws.services.health.model.AffectedEntity Maven / Gradle / Ivy
/*
* Copyright 2012-2017 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.health.model;
import java.io.Serializable;
import javax.annotation.Generated;
/**
*
* Information about an entity that is affected by a Health event.
*
*
* @see AWS API
* Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class AffectedEntity implements Serializable, Cloneable {
/**
*
* The unique identifier for the entity. Format:
* arn:aws:health:entity-region:aws-account:entity/entity-id
. Example:
* arn:aws:health:us-east-1:111222333444:entity/AVh5GGT7ul1arKr1sE1K
*
*/
private String entityArn;
/**
*
* The unique identifier for the event. Format:
* arn:aws:health:event-region::event/EVENT_TYPE_PLUS_ID
. Example:
* arn:aws:health:us-east-1::event/AWS_EC2_MAINTENANCE_5331
*
*/
private String eventArn;
/**
*
* The ID of the affected entity.
*
*/
private String entityValue;
/**
*
* The 12-digit AWS account number that contains the affected entity.
*
*/
private String awsAccountId;
/**
*
* The most recent time that the entity was updated.
*
*/
private java.util.Date lastUpdatedTime;
/**
*
* The most recent status of the entity affected by the event. The possible values are IMPAIRED
,
* UNIMPAIRED
, and UNKNOWN
.
*
*/
private String statusCode;
/**
*
* A map of entity tags attached to the affected entity.
*
*/
private java.util.Map tags;
/**
*
* The unique identifier for the entity. Format:
* arn:aws:health:entity-region:aws-account:entity/entity-id
. Example:
* arn:aws:health:us-east-1:111222333444:entity/AVh5GGT7ul1arKr1sE1K
*
*
* @param entityArn
* The unique identifier for the entity. Format:
* arn:aws:health:entity-region:aws-account:entity/entity-id
. Example:
* arn:aws:health:us-east-1:111222333444:entity/AVh5GGT7ul1arKr1sE1K
*/
public void setEntityArn(String entityArn) {
this.entityArn = entityArn;
}
/**
*
* The unique identifier for the entity. Format:
* arn:aws:health:entity-region:aws-account:entity/entity-id
. Example:
* arn:aws:health:us-east-1:111222333444:entity/AVh5GGT7ul1arKr1sE1K
*
*
* @return The unique identifier for the entity. Format:
* arn:aws:health:entity-region:aws-account:entity/entity-id
. Example:
* arn:aws:health:us-east-1:111222333444:entity/AVh5GGT7ul1arKr1sE1K
*/
public String getEntityArn() {
return this.entityArn;
}
/**
*
* The unique identifier for the entity. Format:
* arn:aws:health:entity-region:aws-account:entity/entity-id
. Example:
* arn:aws:health:us-east-1:111222333444:entity/AVh5GGT7ul1arKr1sE1K
*
*
* @param entityArn
* The unique identifier for the entity. Format:
* arn:aws:health:entity-region:aws-account:entity/entity-id
. Example:
* arn:aws:health:us-east-1:111222333444:entity/AVh5GGT7ul1arKr1sE1K
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AffectedEntity withEntityArn(String entityArn) {
setEntityArn(entityArn);
return this;
}
/**
*
* The unique identifier for the event. Format:
* arn:aws:health:event-region::event/EVENT_TYPE_PLUS_ID
. Example:
* arn:aws:health:us-east-1::event/AWS_EC2_MAINTENANCE_5331
*
*
* @param eventArn
* The unique identifier for the event. Format:
* arn:aws:health:event-region::event/EVENT_TYPE_PLUS_ID
. Example:
* arn:aws:health:us-east-1::event/AWS_EC2_MAINTENANCE_5331
*/
public void setEventArn(String eventArn) {
this.eventArn = eventArn;
}
/**
*
* The unique identifier for the event. Format:
* arn:aws:health:event-region::event/EVENT_TYPE_PLUS_ID
. Example:
* arn:aws:health:us-east-1::event/AWS_EC2_MAINTENANCE_5331
*
*
* @return The unique identifier for the event. Format:
* arn:aws:health:event-region::event/EVENT_TYPE_PLUS_ID
. Example:
* arn:aws:health:us-east-1::event/AWS_EC2_MAINTENANCE_5331
*/
public String getEventArn() {
return this.eventArn;
}
/**
*
* The unique identifier for the event. Format:
* arn:aws:health:event-region::event/EVENT_TYPE_PLUS_ID
. Example:
* arn:aws:health:us-east-1::event/AWS_EC2_MAINTENANCE_5331
*
*
* @param eventArn
* The unique identifier for the event. Format:
* arn:aws:health:event-region::event/EVENT_TYPE_PLUS_ID
. Example:
* arn:aws:health:us-east-1::event/AWS_EC2_MAINTENANCE_5331
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AffectedEntity withEventArn(String eventArn) {
setEventArn(eventArn);
return this;
}
/**
*
* The ID of the affected entity.
*
*
* @param entityValue
* The ID of the affected entity.
*/
public void setEntityValue(String entityValue) {
this.entityValue = entityValue;
}
/**
*
* The ID of the affected entity.
*
*
* @return The ID of the affected entity.
*/
public String getEntityValue() {
return this.entityValue;
}
/**
*
* The ID of the affected entity.
*
*
* @param entityValue
* The ID of the affected entity.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AffectedEntity withEntityValue(String entityValue) {
setEntityValue(entityValue);
return this;
}
/**
*
* The 12-digit AWS account number that contains the affected entity.
*
*
* @param awsAccountId
* The 12-digit AWS account number that contains the affected entity.
*/
public void setAwsAccountId(String awsAccountId) {
this.awsAccountId = awsAccountId;
}
/**
*
* The 12-digit AWS account number that contains the affected entity.
*
*
* @return The 12-digit AWS account number that contains the affected entity.
*/
public String getAwsAccountId() {
return this.awsAccountId;
}
/**
*
* The 12-digit AWS account number that contains the affected entity.
*
*
* @param awsAccountId
* The 12-digit AWS account number that contains the affected entity.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AffectedEntity withAwsAccountId(String awsAccountId) {
setAwsAccountId(awsAccountId);
return this;
}
/**
*
* The most recent time that the entity was updated.
*
*
* @param lastUpdatedTime
* The most recent time that the entity was updated.
*/
public void setLastUpdatedTime(java.util.Date lastUpdatedTime) {
this.lastUpdatedTime = lastUpdatedTime;
}
/**
*
* The most recent time that the entity was updated.
*
*
* @return The most recent time that the entity was updated.
*/
public java.util.Date getLastUpdatedTime() {
return this.lastUpdatedTime;
}
/**
*
* The most recent time that the entity was updated.
*
*
* @param lastUpdatedTime
* The most recent time that the entity was updated.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AffectedEntity withLastUpdatedTime(java.util.Date lastUpdatedTime) {
setLastUpdatedTime(lastUpdatedTime);
return this;
}
/**
*
* The most recent status of the entity affected by the event. The possible values are IMPAIRED
,
* UNIMPAIRED
, and UNKNOWN
.
*
*
* @param statusCode
* The most recent status of the entity affected by the event. The possible values are IMPAIRED
,
* UNIMPAIRED
, and UNKNOWN
.
* @see EntityStatusCode
*/
public void setStatusCode(String statusCode) {
this.statusCode = statusCode;
}
/**
*
* The most recent status of the entity affected by the event. The possible values are IMPAIRED
,
* UNIMPAIRED
, and UNKNOWN
.
*
*
* @return The most recent status of the entity affected by the event. The possible values are IMPAIRED
* , UNIMPAIRED
, and UNKNOWN
.
* @see EntityStatusCode
*/
public String getStatusCode() {
return this.statusCode;
}
/**
*
* The most recent status of the entity affected by the event. The possible values are IMPAIRED
,
* UNIMPAIRED
, and UNKNOWN
.
*
*
* @param statusCode
* The most recent status of the entity affected by the event. The possible values are IMPAIRED
,
* UNIMPAIRED
, and UNKNOWN
.
* @return Returns a reference to this object so that method calls can be chained together.
* @see EntityStatusCode
*/
public AffectedEntity withStatusCode(String statusCode) {
setStatusCode(statusCode);
return this;
}
/**
*
* The most recent status of the entity affected by the event. The possible values are IMPAIRED
,
* UNIMPAIRED
, and UNKNOWN
.
*
*
* @param statusCode
* The most recent status of the entity affected by the event. The possible values are IMPAIRED
,
* UNIMPAIRED
, and UNKNOWN
.
* @see EntityStatusCode
*/
public void setStatusCode(EntityStatusCode statusCode) {
this.statusCode = statusCode.toString();
}
/**
*
* The most recent status of the entity affected by the event. The possible values are IMPAIRED
,
* UNIMPAIRED
, and UNKNOWN
.
*
*
* @param statusCode
* The most recent status of the entity affected by the event. The possible values are IMPAIRED
,
* UNIMPAIRED
, and UNKNOWN
.
* @return Returns a reference to this object so that method calls can be chained together.
* @see EntityStatusCode
*/
public AffectedEntity withStatusCode(EntityStatusCode statusCode) {
setStatusCode(statusCode);
return this;
}
/**
*
* A map of entity tags attached to the affected entity.
*
*
* @return A map of entity tags attached to the affected entity.
*/
public java.util.Map getTags() {
return tags;
}
/**
*
* A map of entity tags attached to the affected entity.
*
*
* @param tags
* A map of entity tags attached to the affected entity.
*/
public void setTags(java.util.Map tags) {
this.tags = tags;
}
/**
*
* A map of entity tags attached to the affected entity.
*
*
* @param tags
* A map of entity tags attached to the affected entity.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AffectedEntity withTags(java.util.Map tags) {
setTags(tags);
return this;
}
public AffectedEntity addTagsEntry(String key, String value) {
if (null == this.tags) {
this.tags = new java.util.HashMap();
}
if (this.tags.containsKey(key))
throw new IllegalArgumentException("Duplicated keys (" + key.toString() + ") are provided.");
this.tags.put(key, value);
return this;
}
/**
* Removes all the entries added into Tags.
*
* @return Returns a reference to this object so that method calls can be chained together.
*/
public AffectedEntity clearTagsEntries() {
this.tags = null;
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 (getEntityArn() != null)
sb.append("EntityArn: ").append(getEntityArn()).append(",");
if (getEventArn() != null)
sb.append("EventArn: ").append(getEventArn()).append(",");
if (getEntityValue() != null)
sb.append("EntityValue: ").append(getEntityValue()).append(",");
if (getAwsAccountId() != null)
sb.append("AwsAccountId: ").append(getAwsAccountId()).append(",");
if (getLastUpdatedTime() != null)
sb.append("LastUpdatedTime: ").append(getLastUpdatedTime()).append(",");
if (getStatusCode() != null)
sb.append("StatusCode: ").append(getStatusCode()).append(",");
if (getTags() != null)
sb.append("Tags: ").append(getTags());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof AffectedEntity == false)
return false;
AffectedEntity other = (AffectedEntity) obj;
if (other.getEntityArn() == null ^ this.getEntityArn() == null)
return false;
if (other.getEntityArn() != null && other.getEntityArn().equals(this.getEntityArn()) == false)
return false;
if (other.getEventArn() == null ^ this.getEventArn() == null)
return false;
if (other.getEventArn() != null && other.getEventArn().equals(this.getEventArn()) == false)
return false;
if (other.getEntityValue() == null ^ this.getEntityValue() == null)
return false;
if (other.getEntityValue() != null && other.getEntityValue().equals(this.getEntityValue()) == false)
return false;
if (other.getAwsAccountId() == null ^ this.getAwsAccountId() == null)
return false;
if (other.getAwsAccountId() != null && other.getAwsAccountId().equals(this.getAwsAccountId()) == false)
return false;
if (other.getLastUpdatedTime() == null ^ this.getLastUpdatedTime() == null)
return false;
if (other.getLastUpdatedTime() != null && other.getLastUpdatedTime().equals(this.getLastUpdatedTime()) == false)
return false;
if (other.getStatusCode() == null ^ this.getStatusCode() == null)
return false;
if (other.getStatusCode() != null && other.getStatusCode().equals(this.getStatusCode()) == false)
return false;
if (other.getTags() == null ^ this.getTags() == null)
return false;
if (other.getTags() != null && other.getTags().equals(this.getTags()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getEntityArn() == null) ? 0 : getEntityArn().hashCode());
hashCode = prime * hashCode + ((getEventArn() == null) ? 0 : getEventArn().hashCode());
hashCode = prime * hashCode + ((getEntityValue() == null) ? 0 : getEntityValue().hashCode());
hashCode = prime * hashCode + ((getAwsAccountId() == null) ? 0 : getAwsAccountId().hashCode());
hashCode = prime * hashCode + ((getLastUpdatedTime() == null) ? 0 : getLastUpdatedTime().hashCode());
hashCode = prime * hashCode + ((getStatusCode() == null) ? 0 : getStatusCode().hashCode());
hashCode = prime * hashCode + ((getTags() == null) ? 0 : getTags().hashCode());
return hashCode;
}
@Override
public AffectedEntity clone() {
try {
return (AffectedEntity) super.clone();
} catch (CloneNotSupportedException e) {
throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e);
}
}
}