/* * Copyright 2010-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.iot.model; import java.io.Serializable; /** *
* Information about an active Device Defender security profile behavior * violation. *
*/ public class ActiveViolation implements Serializable { /** ** The ID of the active violation. *
*
* Constraints:
* Length: 1 - 128
* Pattern: [a-zA-Z0-9\-]+
*/
private String violationId;
/**
*
* The name of the thing responsible for the active violation. *
*
* Constraints:
* Length: 1 - 128
*/
private String thingName;
/**
*
* The security profile with the behavior is in violation. *
*
* Constraints:
* Length: 1 - 128
* Pattern: [a-zA-Z0-9:_-]+
*/
private String securityProfileName;
/**
*
* The behavior that is being violated. *
*/ private Behavior behavior; /** ** The value of the metric (the measurement) that caused the most recent * violation. *
*/ private MetricValue lastViolationValue; /** ** The details of a violation event. *
*/ private ViolationEventAdditionalInfo violationEventAdditionalInfo; /** ** The verification state of the violation (detect alarm). *
*
* Constraints:
* Allowed Values: FALSE_POSITIVE, BENIGN_POSITIVE, TRUE_POSITIVE,
* UNKNOWN
*/
private String verificationState;
/**
*
* The description of the verification state of the violation. *
*
* Constraints:
* Length: - 1000
* Pattern: [^\p{Cntrl}]*
*/
private String verificationStateDescription;
/**
*
* The time the most recent violation occurred. *
*/ private java.util.Date lastViolationTime; /** ** The time the violation started. *
*/ private java.util.Date violationStartTime; /** ** The ID of the active violation. *
*
* Constraints:
* Length: 1 - 128
* Pattern: [a-zA-Z0-9\-]+
*
* @return
* The ID of the active violation. *
*/ public String getViolationId() { return violationId; } /** ** The ID of the active violation. *
*
* Constraints:
* Length: 1 - 128
* Pattern: [a-zA-Z0-9\-]+
*
* @param violationId
* The ID of the active violation. *
*/ public void setViolationId(String violationId) { this.violationId = violationId; } /** ** The ID of the active violation. *
** Returns a reference to this object so that method calls can be chained * together. *
* Constraints:
* Length: 1 - 128
* Pattern: [a-zA-Z0-9\-]+
*
* @param violationId
* The ID of the active violation. *
* @return A reference to this updated object so that method calls can be * chained together. */ public ActiveViolation withViolationId(String violationId) { this.violationId = violationId; return this; } /** ** The name of the thing responsible for the active violation. *
*
* Constraints:
* Length: 1 - 128
*
* @return
* The name of the thing responsible for the active violation. *
*/ public String getThingName() { return thingName; } /** ** The name of the thing responsible for the active violation. *
*
* Constraints:
* Length: 1 - 128
*
* @param thingName
* The name of the thing responsible for the active violation. *
*/ public void setThingName(String thingName) { this.thingName = thingName; } /** ** The name of the thing responsible for the active violation. *
** Returns a reference to this object so that method calls can be chained * together. *
* Constraints:
* Length: 1 - 128
*
* @param thingName
* The name of the thing responsible for the active violation. *
* @return A reference to this updated object so that method calls can be * chained together. */ public ActiveViolation withThingName(String thingName) { this.thingName = thingName; return this; } /** ** The security profile with the behavior is in violation. *
*
* Constraints:
* Length: 1 - 128
* Pattern: [a-zA-Z0-9:_-]+
*
* @return
* The security profile with the behavior is in violation. *
*/ public String getSecurityProfileName() { return securityProfileName; } /** ** The security profile with the behavior is in violation. *
*
* Constraints:
* Length: 1 - 128
* Pattern: [a-zA-Z0-9:_-]+
*
* @param securityProfileName
* The security profile with the behavior is in violation. *
*/ public void setSecurityProfileName(String securityProfileName) { this.securityProfileName = securityProfileName; } /** ** The security profile with the behavior is in violation. *
** Returns a reference to this object so that method calls can be chained * together. *
* Constraints:
* Length: 1 - 128
* Pattern: [a-zA-Z0-9:_-]+
*
* @param securityProfileName
* The security profile with the behavior is in violation. *
* @return A reference to this updated object so that method calls can be * chained together. */ public ActiveViolation withSecurityProfileName(String securityProfileName) { this.securityProfileName = securityProfileName; return this; } /** ** The behavior that is being violated. *
* * @return* The behavior that is being violated. *
*/ public Behavior getBehavior() { return behavior; } /** ** The behavior that is being violated. *
* * @param behavior* The behavior that is being violated. *
*/ public void setBehavior(Behavior behavior) { this.behavior = behavior; } /** ** The behavior that is being violated. *
** Returns a reference to this object so that method calls can be chained * together. * * @param behavior
* The behavior that is being violated. *
* @return A reference to this updated object so that method calls can be * chained together. */ public ActiveViolation withBehavior(Behavior behavior) { this.behavior = behavior; return this; } /** ** The value of the metric (the measurement) that caused the most recent * violation. *
* * @return* The value of the metric (the measurement) that caused the most * recent violation. *
*/ public MetricValue getLastViolationValue() { return lastViolationValue; } /** ** The value of the metric (the measurement) that caused the most recent * violation. *
* * @param lastViolationValue* The value of the metric (the measurement) that caused the most * recent violation. *
*/ public void setLastViolationValue(MetricValue lastViolationValue) { this.lastViolationValue = lastViolationValue; } /** ** The value of the metric (the measurement) that caused the most recent * violation. *
** Returns a reference to this object so that method calls can be chained * together. * * @param lastViolationValue
* The value of the metric (the measurement) that caused the most * recent violation. *
* @return A reference to this updated object so that method calls can be * chained together. */ public ActiveViolation withLastViolationValue(MetricValue lastViolationValue) { this.lastViolationValue = lastViolationValue; return this; } /** ** The details of a violation event. *
* * @return* The details of a violation event. *
*/ public ViolationEventAdditionalInfo getViolationEventAdditionalInfo() { return violationEventAdditionalInfo; } /** ** The details of a violation event. *
* * @param violationEventAdditionalInfo* The details of a violation event. *
*/ public void setViolationEventAdditionalInfo( ViolationEventAdditionalInfo violationEventAdditionalInfo) { this.violationEventAdditionalInfo = violationEventAdditionalInfo; } /** ** The details of a violation event. *
** Returns a reference to this object so that method calls can be chained * together. * * @param violationEventAdditionalInfo
* The details of a violation event. *
* @return A reference to this updated object so that method calls can be * chained together. */ public ActiveViolation withViolationEventAdditionalInfo( ViolationEventAdditionalInfo violationEventAdditionalInfo) { this.violationEventAdditionalInfo = violationEventAdditionalInfo; return this; } /** ** The verification state of the violation (detect alarm). *
*
* Constraints:
* Allowed Values: FALSE_POSITIVE, BENIGN_POSITIVE, TRUE_POSITIVE,
* UNKNOWN
*
* @return
* The verification state of the violation (detect alarm). *
* @see VerificationState */ public String getVerificationState() { return verificationState; } /** ** The verification state of the violation (detect alarm). *
*
* Constraints:
* Allowed Values: FALSE_POSITIVE, BENIGN_POSITIVE, TRUE_POSITIVE,
* UNKNOWN
*
* @param verificationState
* The verification state of the violation (detect alarm). *
* @see VerificationState */ public void setVerificationState(String verificationState) { this.verificationState = verificationState; } /** ** The verification state of the violation (detect alarm). *
** Returns a reference to this object so that method calls can be chained * together. *
* Constraints:
* Allowed Values: FALSE_POSITIVE, BENIGN_POSITIVE, TRUE_POSITIVE,
* UNKNOWN
*
* @param verificationState
* The verification state of the violation (detect alarm). *
* @return A reference to this updated object so that method calls can be * chained together. * @see VerificationState */ public ActiveViolation withVerificationState(String verificationState) { this.verificationState = verificationState; return this; } /** ** The verification state of the violation (detect alarm). *
*
* Constraints:
* Allowed Values: FALSE_POSITIVE, BENIGN_POSITIVE, TRUE_POSITIVE,
* UNKNOWN
*
* @param verificationState
* The verification state of the violation (detect alarm). *
* @see VerificationState */ public void setVerificationState(VerificationState verificationState) { this.verificationState = verificationState.toString(); } /** ** The verification state of the violation (detect alarm). *
** Returns a reference to this object so that method calls can be chained * together. *
* Constraints:
* Allowed Values: FALSE_POSITIVE, BENIGN_POSITIVE, TRUE_POSITIVE,
* UNKNOWN
*
* @param verificationState
* The verification state of the violation (detect alarm). *
* @return A reference to this updated object so that method calls can be * chained together. * @see VerificationState */ public ActiveViolation withVerificationState(VerificationState verificationState) { this.verificationState = verificationState.toString(); return this; } /** ** The description of the verification state of the violation. *
*
* Constraints:
* Length: - 1000
* Pattern: [^\p{Cntrl}]*
*
* @return
* The description of the verification state of the violation. *
*/ public String getVerificationStateDescription() { return verificationStateDescription; } /** ** The description of the verification state of the violation. *
*
* Constraints:
* Length: - 1000
* Pattern: [^\p{Cntrl}]*
*
* @param verificationStateDescription
* The description of the verification state of the violation. *
*/ public void setVerificationStateDescription(String verificationStateDescription) { this.verificationStateDescription = verificationStateDescription; } /** ** The description of the verification state of the violation. *
** Returns a reference to this object so that method calls can be chained * together. *
* Constraints:
* Length: - 1000
* Pattern: [^\p{Cntrl}]*
*
* @param verificationStateDescription
* The description of the verification state of the violation. *
* @return A reference to this updated object so that method calls can be * chained together. */ public ActiveViolation withVerificationStateDescription(String verificationStateDescription) { this.verificationStateDescription = verificationStateDescription; return this; } /** ** The time the most recent violation occurred. *
* * @return* The time the most recent violation occurred. *
*/ public java.util.Date getLastViolationTime() { return lastViolationTime; } /** ** The time the most recent violation occurred. *
* * @param lastViolationTime* The time the most recent violation occurred. *
*/ public void setLastViolationTime(java.util.Date lastViolationTime) { this.lastViolationTime = lastViolationTime; } /** ** The time the most recent violation occurred. *
** Returns a reference to this object so that method calls can be chained * together. * * @param lastViolationTime
* The time the most recent violation occurred. *
* @return A reference to this updated object so that method calls can be * chained together. */ public ActiveViolation withLastViolationTime(java.util.Date lastViolationTime) { this.lastViolationTime = lastViolationTime; return this; } /** ** The time the violation started. *
* * @return* The time the violation started. *
*/ public java.util.Date getViolationStartTime() { return violationStartTime; } /** ** The time the violation started. *
* * @param violationStartTime* The time the violation started. *
*/ public void setViolationStartTime(java.util.Date violationStartTime) { this.violationStartTime = violationStartTime; } /** ** The time the violation started. *
** Returns a reference to this object so that method calls can be chained * together. * * @param violationStartTime
* The time the violation started. *
* @return A reference to this updated object so that method calls can be * chained together. */ public ActiveViolation withViolationStartTime(java.util.Date violationStartTime) { this.violationStartTime = violationStartTime; 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 (getViolationId() != null) sb.append("violationId: " + getViolationId() + ","); if (getThingName() != null) sb.append("thingName: " + getThingName() + ","); if (getSecurityProfileName() != null) sb.append("securityProfileName: " + getSecurityProfileName() + ","); if (getBehavior() != null) sb.append("behavior: " + getBehavior() + ","); if (getLastViolationValue() != null) sb.append("lastViolationValue: " + getLastViolationValue() + ","); if (getViolationEventAdditionalInfo() != null) sb.append("violationEventAdditionalInfo: " + getViolationEventAdditionalInfo() + ","); if (getVerificationState() != null) sb.append("verificationState: " + getVerificationState() + ","); if (getVerificationStateDescription() != null) sb.append("verificationStateDescription: " + getVerificationStateDescription() + ","); if (getLastViolationTime() != null) sb.append("lastViolationTime: " + getLastViolationTime() + ","); if (getViolationStartTime() != null) sb.append("violationStartTime: " + getViolationStartTime()); sb.append("}"); return sb.toString(); } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getViolationId() == null) ? 0 : getViolationId().hashCode()); hashCode = prime * hashCode + ((getThingName() == null) ? 0 : getThingName().hashCode()); hashCode = prime * hashCode + ((getSecurityProfileName() == null) ? 0 : getSecurityProfileName().hashCode()); hashCode = prime * hashCode + ((getBehavior() == null) ? 0 : getBehavior().hashCode()); hashCode = prime * hashCode + ((getLastViolationValue() == null) ? 0 : getLastViolationValue().hashCode()); hashCode = prime * hashCode + ((getViolationEventAdditionalInfo() == null) ? 0 : getViolationEventAdditionalInfo().hashCode()); hashCode = prime * hashCode + ((getVerificationState() == null) ? 0 : getVerificationState().hashCode()); hashCode = prime * hashCode + ((getVerificationStateDescription() == null) ? 0 : getVerificationStateDescription().hashCode()); hashCode = prime * hashCode + ((getLastViolationTime() == null) ? 0 : getLastViolationTime().hashCode()); hashCode = prime * hashCode + ((getViolationStartTime() == null) ? 0 : getViolationStartTime().hashCode()); return hashCode; } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof ActiveViolation == false) return false; ActiveViolation other = (ActiveViolation) obj; if (other.getViolationId() == null ^ this.getViolationId() == null) return false; if (other.getViolationId() != null && other.getViolationId().equals(this.getViolationId()) == false) return false; if (other.getThingName() == null ^ this.getThingName() == null) return false; if (other.getThingName() != null && other.getThingName().equals(this.getThingName()) == false) return false; if (other.getSecurityProfileName() == null ^ this.getSecurityProfileName() == null) return false; if (other.getSecurityProfileName() != null && other.getSecurityProfileName().equals(this.getSecurityProfileName()) == false) return false; if (other.getBehavior() == null ^ this.getBehavior() == null) return false; if (other.getBehavior() != null && other.getBehavior().equals(this.getBehavior()) == false) return false; if (other.getLastViolationValue() == null ^ this.getLastViolationValue() == null) return false; if (other.getLastViolationValue() != null && other.getLastViolationValue().equals(this.getLastViolationValue()) == false) return false; if (other.getViolationEventAdditionalInfo() == null ^ this.getViolationEventAdditionalInfo() == null) return false; if (other.getViolationEventAdditionalInfo() != null && other.getViolationEventAdditionalInfo().equals( this.getViolationEventAdditionalInfo()) == false) return false; if (other.getVerificationState() == null ^ this.getVerificationState() == null) return false; if (other.getVerificationState() != null && other.getVerificationState().equals(this.getVerificationState()) == false) return false; if (other.getVerificationStateDescription() == null ^ this.getVerificationStateDescription() == null) return false; if (other.getVerificationStateDescription() != null && other.getVerificationStateDescription().equals( this.getVerificationStateDescription()) == false) return false; if (other.getLastViolationTime() == null ^ this.getLastViolationTime() == null) return false; if (other.getLastViolationTime() != null && other.getLastViolationTime().equals(this.getLastViolationTime()) == false) return false; if (other.getViolationStartTime() == null ^ this.getViolationStartTime() == null) return false; if (other.getViolationStartTime() != null && other.getViolationStartTime().equals(this.getViolationStartTime()) == false) return false; return true; } }