com.amazonaws.services.iotevents.model.DetectorModelConfiguration Maven / Gradle / Ivy
/*
* Copyright 2016-2021 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.iotevents.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;
/**
*
* Information about how the detector model is configured.
*
*
* @see AWS API Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class DetectorModelConfiguration implements Serializable, Cloneable, StructuredPojo {
/**
*
* The name of the detector model.
*
*/
private String detectorModelName;
/**
*
* The version of the detector model.
*
*/
private String detectorModelVersion;
/**
*
* A brief description of the detector model.
*
*/
private String detectorModelDescription;
/**
*
* The ARN of the detector model.
*
*/
private String detectorModelArn;
/**
*
* The ARN of the role that grants permission to AWS IoT Events to perform its operations.
*
*/
private String roleArn;
/**
*
* The time the detector model was created.
*
*/
private java.util.Date creationTime;
/**
*
* The time the detector model was last updated.
*
*/
private java.util.Date lastUpdateTime;
/**
*
* The status of the detector model.
*
*/
private String status;
/**
*
* The value used to identify a detector instance. When a device or system sends input, a new detector instance with
* a unique key value is created. AWS IoT Events can continue to route input to its corresponding detector instance
* based on this identifying information.
*
*
* This parameter uses a JSON-path expression to select the attribute-value pair in the message payload that is used
* for identification. To route the message to the correct detector instance, the device must send a message payload
* that contains the same attribute-value.
*
*/
private String key;
/**
*
* Information about the order in which events are evaluated and how actions are executed.
*
*/
private String evaluationMethod;
/**
*
* The name of the detector model.
*
*
* @param detectorModelName
* The name of the detector model.
*/
public void setDetectorModelName(String detectorModelName) {
this.detectorModelName = detectorModelName;
}
/**
*
* The name of the detector model.
*
*
* @return The name of the detector model.
*/
public String getDetectorModelName() {
return this.detectorModelName;
}
/**
*
* The name of the detector model.
*
*
* @param detectorModelName
* The name of the detector model.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public DetectorModelConfiguration withDetectorModelName(String detectorModelName) {
setDetectorModelName(detectorModelName);
return this;
}
/**
*
* The version of the detector model.
*
*
* @param detectorModelVersion
* The version of the detector model.
*/
public void setDetectorModelVersion(String detectorModelVersion) {
this.detectorModelVersion = detectorModelVersion;
}
/**
*
* The version of the detector model.
*
*
* @return The version of the detector model.
*/
public String getDetectorModelVersion() {
return this.detectorModelVersion;
}
/**
*
* The version of the detector model.
*
*
* @param detectorModelVersion
* The version of the detector model.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public DetectorModelConfiguration withDetectorModelVersion(String detectorModelVersion) {
setDetectorModelVersion(detectorModelVersion);
return this;
}
/**
*
* A brief description of the detector model.
*
*
* @param detectorModelDescription
* A brief description of the detector model.
*/
public void setDetectorModelDescription(String detectorModelDescription) {
this.detectorModelDescription = detectorModelDescription;
}
/**
*
* A brief description of the detector model.
*
*
* @return A brief description of the detector model.
*/
public String getDetectorModelDescription() {
return this.detectorModelDescription;
}
/**
*
* A brief description of the detector model.
*
*
* @param detectorModelDescription
* A brief description of the detector model.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public DetectorModelConfiguration withDetectorModelDescription(String detectorModelDescription) {
setDetectorModelDescription(detectorModelDescription);
return this;
}
/**
*
* The ARN of the detector model.
*
*
* @param detectorModelArn
* The ARN of the detector model.
*/
public void setDetectorModelArn(String detectorModelArn) {
this.detectorModelArn = detectorModelArn;
}
/**
*
* The ARN of the detector model.
*
*
* @return The ARN of the detector model.
*/
public String getDetectorModelArn() {
return this.detectorModelArn;
}
/**
*
* The ARN of the detector model.
*
*
* @param detectorModelArn
* The ARN of the detector model.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public DetectorModelConfiguration withDetectorModelArn(String detectorModelArn) {
setDetectorModelArn(detectorModelArn);
return this;
}
/**
*
* The ARN of the role that grants permission to AWS IoT Events to perform its operations.
*
*
* @param roleArn
* The ARN of the role that grants permission to AWS IoT Events to perform its operations.
*/
public void setRoleArn(String roleArn) {
this.roleArn = roleArn;
}
/**
*
* The ARN of the role that grants permission to AWS IoT Events to perform its operations.
*
*
* @return The ARN of the role that grants permission to AWS IoT Events to perform its operations.
*/
public String getRoleArn() {
return this.roleArn;
}
/**
*
* The ARN of the role that grants permission to AWS IoT Events to perform its operations.
*
*
* @param roleArn
* The ARN of the role that grants permission to AWS IoT Events to perform its operations.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public DetectorModelConfiguration withRoleArn(String roleArn) {
setRoleArn(roleArn);
return this;
}
/**
*
* The time the detector model was created.
*
*
* @param creationTime
* The time the detector model was created.
*/
public void setCreationTime(java.util.Date creationTime) {
this.creationTime = creationTime;
}
/**
*
* The time the detector model was created.
*
*
* @return The time the detector model was created.
*/
public java.util.Date getCreationTime() {
return this.creationTime;
}
/**
*
* The time the detector model was created.
*
*
* @param creationTime
* The time the detector model was created.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public DetectorModelConfiguration withCreationTime(java.util.Date creationTime) {
setCreationTime(creationTime);
return this;
}
/**
*
* The time the detector model was last updated.
*
*
* @param lastUpdateTime
* The time the detector model was last updated.
*/
public void setLastUpdateTime(java.util.Date lastUpdateTime) {
this.lastUpdateTime = lastUpdateTime;
}
/**
*
* The time the detector model was last updated.
*
*
* @return The time the detector model was last updated.
*/
public java.util.Date getLastUpdateTime() {
return this.lastUpdateTime;
}
/**
*
* The time the detector model was last updated.
*
*
* @param lastUpdateTime
* The time the detector model was last updated.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public DetectorModelConfiguration withLastUpdateTime(java.util.Date lastUpdateTime) {
setLastUpdateTime(lastUpdateTime);
return this;
}
/**
*
* The status of the detector model.
*
*
* @param status
* The status of the detector model.
* @see DetectorModelVersionStatus
*/
public void setStatus(String status) {
this.status = status;
}
/**
*
* The status of the detector model.
*
*
* @return The status of the detector model.
* @see DetectorModelVersionStatus
*/
public String getStatus() {
return this.status;
}
/**
*
* The status of the detector model.
*
*
* @param status
* The status of the detector model.
* @return Returns a reference to this object so that method calls can be chained together.
* @see DetectorModelVersionStatus
*/
public DetectorModelConfiguration withStatus(String status) {
setStatus(status);
return this;
}
/**
*
* The status of the detector model.
*
*
* @param status
* The status of the detector model.
* @return Returns a reference to this object so that method calls can be chained together.
* @see DetectorModelVersionStatus
*/
public DetectorModelConfiguration withStatus(DetectorModelVersionStatus status) {
this.status = status.toString();
return this;
}
/**
*
* The value used to identify a detector instance. When a device or system sends input, a new detector instance with
* a unique key value is created. AWS IoT Events can continue to route input to its corresponding detector instance
* based on this identifying information.
*
*
* This parameter uses a JSON-path expression to select the attribute-value pair in the message payload that is used
* for identification. To route the message to the correct detector instance, the device must send a message payload
* that contains the same attribute-value.
*
*
* @param key
* The value used to identify a detector instance. When a device or system sends input, a new detector
* instance with a unique key value is created. AWS IoT Events can continue to route input to its
* corresponding detector instance based on this identifying information.
*
* This parameter uses a JSON-path expression to select the attribute-value pair in the message payload that
* is used for identification. To route the message to the correct detector instance, the device must send a
* message payload that contains the same attribute-value.
*/
public void setKey(String key) {
this.key = key;
}
/**
*
* The value used to identify a detector instance. When a device or system sends input, a new detector instance with
* a unique key value is created. AWS IoT Events can continue to route input to its corresponding detector instance
* based on this identifying information.
*
*
* This parameter uses a JSON-path expression to select the attribute-value pair in the message payload that is used
* for identification. To route the message to the correct detector instance, the device must send a message payload
* that contains the same attribute-value.
*
*
* @return The value used to identify a detector instance. When a device or system sends input, a new detector
* instance with a unique key value is created. AWS IoT Events can continue to route input to its
* corresponding detector instance based on this identifying information.
*
* This parameter uses a JSON-path expression to select the attribute-value pair in the message payload that
* is used for identification. To route the message to the correct detector instance, the device must send a
* message payload that contains the same attribute-value.
*/
public String getKey() {
return this.key;
}
/**
*
* The value used to identify a detector instance. When a device or system sends input, a new detector instance with
* a unique key value is created. AWS IoT Events can continue to route input to its corresponding detector instance
* based on this identifying information.
*
*
* This parameter uses a JSON-path expression to select the attribute-value pair in the message payload that is used
* for identification. To route the message to the correct detector instance, the device must send a message payload
* that contains the same attribute-value.
*
*
* @param key
* The value used to identify a detector instance. When a device or system sends input, a new detector
* instance with a unique key value is created. AWS IoT Events can continue to route input to its
* corresponding detector instance based on this identifying information.
*
* This parameter uses a JSON-path expression to select the attribute-value pair in the message payload that
* is used for identification. To route the message to the correct detector instance, the device must send a
* message payload that contains the same attribute-value.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public DetectorModelConfiguration withKey(String key) {
setKey(key);
return this;
}
/**
*
* Information about the order in which events are evaluated and how actions are executed.
*
*
* @param evaluationMethod
* Information about the order in which events are evaluated and how actions are executed.
* @see EvaluationMethod
*/
public void setEvaluationMethod(String evaluationMethod) {
this.evaluationMethod = evaluationMethod;
}
/**
*
* Information about the order in which events are evaluated and how actions are executed.
*
*
* @return Information about the order in which events are evaluated and how actions are executed.
* @see EvaluationMethod
*/
public String getEvaluationMethod() {
return this.evaluationMethod;
}
/**
*
* Information about the order in which events are evaluated and how actions are executed.
*
*
* @param evaluationMethod
* Information about the order in which events are evaluated and how actions are executed.
* @return Returns a reference to this object so that method calls can be chained together.
* @see EvaluationMethod
*/
public DetectorModelConfiguration withEvaluationMethod(String evaluationMethod) {
setEvaluationMethod(evaluationMethod);
return this;
}
/**
*
* Information about the order in which events are evaluated and how actions are executed.
*
*
* @param evaluationMethod
* Information about the order in which events are evaluated and how actions are executed.
* @return Returns a reference to this object so that method calls can be chained together.
* @see EvaluationMethod
*/
public DetectorModelConfiguration withEvaluationMethod(EvaluationMethod evaluationMethod) {
this.evaluationMethod = evaluationMethod.toString();
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 (getDetectorModelName() != null)
sb.append("DetectorModelName: ").append(getDetectorModelName()).append(",");
if (getDetectorModelVersion() != null)
sb.append("DetectorModelVersion: ").append(getDetectorModelVersion()).append(",");
if (getDetectorModelDescription() != null)
sb.append("DetectorModelDescription: ").append(getDetectorModelDescription()).append(",");
if (getDetectorModelArn() != null)
sb.append("DetectorModelArn: ").append(getDetectorModelArn()).append(",");
if (getRoleArn() != null)
sb.append("RoleArn: ").append(getRoleArn()).append(",");
if (getCreationTime() != null)
sb.append("CreationTime: ").append(getCreationTime()).append(",");
if (getLastUpdateTime() != null)
sb.append("LastUpdateTime: ").append(getLastUpdateTime()).append(",");
if (getStatus() != null)
sb.append("Status: ").append(getStatus()).append(",");
if (getKey() != null)
sb.append("Key: ").append(getKey()).append(",");
if (getEvaluationMethod() != null)
sb.append("EvaluationMethod: ").append(getEvaluationMethod());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof DetectorModelConfiguration == false)
return false;
DetectorModelConfiguration other = (DetectorModelConfiguration) obj;
if (other.getDetectorModelName() == null ^ this.getDetectorModelName() == null)
return false;
if (other.getDetectorModelName() != null && other.getDetectorModelName().equals(this.getDetectorModelName()) == false)
return false;
if (other.getDetectorModelVersion() == null ^ this.getDetectorModelVersion() == null)
return false;
if (other.getDetectorModelVersion() != null && other.getDetectorModelVersion().equals(this.getDetectorModelVersion()) == false)
return false;
if (other.getDetectorModelDescription() == null ^ this.getDetectorModelDescription() == null)
return false;
if (other.getDetectorModelDescription() != null && other.getDetectorModelDescription().equals(this.getDetectorModelDescription()) == false)
return false;
if (other.getDetectorModelArn() == null ^ this.getDetectorModelArn() == null)
return false;
if (other.getDetectorModelArn() != null && other.getDetectorModelArn().equals(this.getDetectorModelArn()) == false)
return false;
if (other.getRoleArn() == null ^ this.getRoleArn() == null)
return false;
if (other.getRoleArn() != null && other.getRoleArn().equals(this.getRoleArn()) == false)
return false;
if (other.getCreationTime() == null ^ this.getCreationTime() == null)
return false;
if (other.getCreationTime() != null && other.getCreationTime().equals(this.getCreationTime()) == false)
return false;
if (other.getLastUpdateTime() == null ^ this.getLastUpdateTime() == null)
return false;
if (other.getLastUpdateTime() != null && other.getLastUpdateTime().equals(this.getLastUpdateTime()) == false)
return false;
if (other.getStatus() == null ^ this.getStatus() == null)
return false;
if (other.getStatus() != null && other.getStatus().equals(this.getStatus()) == false)
return false;
if (other.getKey() == null ^ this.getKey() == null)
return false;
if (other.getKey() != null && other.getKey().equals(this.getKey()) == false)
return false;
if (other.getEvaluationMethod() == null ^ this.getEvaluationMethod() == null)
return false;
if (other.getEvaluationMethod() != null && other.getEvaluationMethod().equals(this.getEvaluationMethod()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getDetectorModelName() == null) ? 0 : getDetectorModelName().hashCode());
hashCode = prime * hashCode + ((getDetectorModelVersion() == null) ? 0 : getDetectorModelVersion().hashCode());
hashCode = prime * hashCode + ((getDetectorModelDescription() == null) ? 0 : getDetectorModelDescription().hashCode());
hashCode = prime * hashCode + ((getDetectorModelArn() == null) ? 0 : getDetectorModelArn().hashCode());
hashCode = prime * hashCode + ((getRoleArn() == null) ? 0 : getRoleArn().hashCode());
hashCode = prime * hashCode + ((getCreationTime() == null) ? 0 : getCreationTime().hashCode());
hashCode = prime * hashCode + ((getLastUpdateTime() == null) ? 0 : getLastUpdateTime().hashCode());
hashCode = prime * hashCode + ((getStatus() == null) ? 0 : getStatus().hashCode());
hashCode = prime * hashCode + ((getKey() == null) ? 0 : getKey().hashCode());
hashCode = prime * hashCode + ((getEvaluationMethod() == null) ? 0 : getEvaluationMethod().hashCode());
return hashCode;
}
@Override
public DetectorModelConfiguration clone() {
try {
return (DetectorModelConfiguration) 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.iotevents.model.transform.DetectorModelConfigurationMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}