/* * 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.comprehend.model; import java.io.Serializable; /** *

* Provides information about a topic detection job. *

*/ public class TopicsDetectionJobProperties implements Serializable { /** *

* The identifier assigned to the topic detection job. *

*

* Constraints:
* Length: 1 - 32
* Pattern: ^([\p{L}\p{Z}\p{N}_.:/=+\-%@]*)$
*/ private String jobId; /** *

* The Amazon Resource Name (ARN) of the topics detection job. It is a * unique, fully qualified identifier for the job. It includes the Amazon * Web Services account, Amazon Web Services Region, and the job ID. The * format of the ARN is as follows: *

*

* arn:<partition>:comprehend:<region>:<account-id>:topics-detection-job/<job-id> *

*

* The following is an example job ARN: *

*

* arn:aws:comprehend:us-west-2:111122223333:topics-detection-job/1234abcd12ab34cd56ef1234567890ab *

*

* Constraints:
* Length: - 256
* Pattern: * arn:aws(-[^:]+)?:comprehend:[a-zA-Z0-9-]*:[0-9]{12}:[a-zA- * Z0-9-]{1,64} * /[a-zA-Z0-9](-*[a-zA-Z0-9])*((/dataset/[a-zA-Z0-9](-*[a-zA-Z0- * 9])*)|(/version/[a-zA-Z0-9](-*[a-zA-Z0-9])*))?
*/ private String jobArn; /** *

* The name of the topic detection job. *

*

* Constraints:
* Length: 1 - 256
* Pattern: ^([\p{L}\p{Z}\p{N}_.:/=+\-%@]*)$
*/ private String jobName; /** *

* The current status of the topic detection job. If the status is * Failed, the reason for the failure is shown in the * Message field. *

*

* Constraints:
* Allowed Values: SUBMITTED, IN_PROGRESS, COMPLETED, FAILED, * STOP_REQUESTED, STOPPED */ private String jobStatus; /** *

* A description for the status of a job. *

*/ private String message; /** *

* The time that the topic detection job was submitted for processing. *

*/ private java.util.Date submitTime; /** *

* The time that the topic detection job was completed. *

*/ private java.util.Date endTime; /** *

* The input data configuration supplied when you created the topic * detection job. *

*/ private InputDataConfig inputDataConfig; /** *

* The output data configuration supplied when you created the topic * detection job. *

*/ private OutputDataConfig outputDataConfig; /** *

* The number of topics to detect supplied when you created the topic * detection job. The default is 10. *

*/ private Integer numberOfTopics; /** *

* The Amazon Resource Name (ARN) of the IAM role that grants Amazon * Comprehend read access to your job data. *

*

* Constraints:
* Length: 20 - 2048
* Pattern: arn:aws(-[^:]+)?:iam::[0-9]{12}:role/.+
*/ private String dataAccessRoleArn; /** *

* ID for the Amazon Web Services Key Management Service (KMS) key that * Amazon Comprehend uses to encrypt data on the storage volume attached to * the ML compute instance(s) that process the analysis job. The * VolumeKmsKeyId can be either of the following formats: *

* *

* Constraints:
* Length: - 2048
* Pattern: ^\p{ASCII}+$
*/ private String volumeKmsKeyId; /** *

* Configuration parameters for a private Virtual Private Cloud (VPC) * containing the resources you are using for your topic detection job. For * more information, see Amazon VPC. *

*/ private VpcConfig vpcConfig; /** *

* The identifier assigned to the topic detection job. *

*

* Constraints:
* Length: 1 - 32
* Pattern: ^([\p{L}\p{Z}\p{N}_.:/=+\-%@]*)$
* * @return

* The identifier assigned to the topic detection job. *

*/ public String getJobId() { return jobId; } /** *

* The identifier assigned to the topic detection job. *

*

* Constraints:
* Length: 1 - 32
* Pattern: ^([\p{L}\p{Z}\p{N}_.:/=+\-%@]*)$
* * @param jobId

* The identifier assigned to the topic detection job. *

*/ public void setJobId(String jobId) { this.jobId = jobId; } /** *

* The identifier assigned to the topic detection job. *

*

* Returns a reference to this object so that method calls can be chained * together. *

* Constraints:
* Length: 1 - 32
* Pattern: ^([\p{L}\p{Z}\p{N}_.:/=+\-%@]*)$
* * @param jobId

* The identifier assigned to the topic detection job. *

* @return A reference to this updated object so that method calls can be * chained together. */ public TopicsDetectionJobProperties withJobId(String jobId) { this.jobId = jobId; return this; } /** *

* The Amazon Resource Name (ARN) of the topics detection job. It is a * unique, fully qualified identifier for the job. It includes the Amazon * Web Services account, Amazon Web Services Region, and the job ID. The * format of the ARN is as follows: *

*

* arn:<partition>:comprehend:<region>:<account-id>:topics-detection-job/<job-id> *

*

* The following is an example job ARN: *

*

* arn:aws:comprehend:us-west-2:111122223333:topics-detection-job/1234abcd12ab34cd56ef1234567890ab *

*

* Constraints:
* Length: - 256
* Pattern: * arn:aws(-[^:]+)?:comprehend:[a-zA-Z0-9-]*:[0-9]{12}:[a-zA- * Z0-9-]{1,64} * /[a-zA-Z0-9](-*[a-zA-Z0-9])*((/dataset/[a-zA-Z0-9](-*[a-zA-Z0- * 9])*)|(/version/[a-zA-Z0-9](-*[a-zA-Z0-9])*))?
* * @return

* The Amazon Resource Name (ARN) of the topics detection job. It is * a unique, fully qualified identifier for the job. It includes the * Amazon Web Services account, Amazon Web Services Region, and the * job ID. The format of the ARN is as follows: *

*

* arn:<partition>:comprehend:<region>:<account-id>:topics-detection-job/<job-id> *

*

* The following is an example job ARN: *

*

* arn:aws:comprehend:us-west-2:111122223333:topics-detection-job/1234abcd12ab34cd56ef1234567890ab *

*/ public String getJobArn() { return jobArn; } /** *

* The Amazon Resource Name (ARN) of the topics detection job. It is a * unique, fully qualified identifier for the job. It includes the Amazon * Web Services account, Amazon Web Services Region, and the job ID. The * format of the ARN is as follows: *

*

* arn:<partition>:comprehend:<region>:<account-id>:topics-detection-job/<job-id> *

*

* The following is an example job ARN: *

*

* arn:aws:comprehend:us-west-2:111122223333:topics-detection-job/1234abcd12ab34cd56ef1234567890ab *

*

* Constraints:
* Length: - 256
* Pattern: * arn:aws(-[^:]+)?:comprehend:[a-zA-Z0-9-]*:[0-9]{12}:[a-zA- * Z0-9-]{1,64} * /[a-zA-Z0-9](-*[a-zA-Z0-9])*((/dataset/[a-zA-Z0-9](-*[a-zA-Z0- * 9])*)|(/version/[a-zA-Z0-9](-*[a-zA-Z0-9])*))?
* * @param jobArn

* The Amazon Resource Name (ARN) of the topics detection job. It * is a unique, fully qualified identifier for the job. It * includes the Amazon Web Services account, Amazon Web Services * Region, and the job ID. The format of the ARN is as follows: *

*

* arn:<partition>:comprehend:<region>:<account-id>:topics-detection-job/<job-id> *

*

* The following is an example job ARN: *

*

* arn:aws:comprehend:us-west-2:111122223333:topics-detection-job/1234abcd12ab34cd56ef1234567890ab *

*/ public void setJobArn(String jobArn) { this.jobArn = jobArn; } /** *

* The Amazon Resource Name (ARN) of the topics detection job. It is a * unique, fully qualified identifier for the job. It includes the Amazon * Web Services account, Amazon Web Services Region, and the job ID. The * format of the ARN is as follows: *

*

* arn:<partition>:comprehend:<region>:<account-id>:topics-detection-job/<job-id> *

*

* The following is an example job ARN: *

*

* arn:aws:comprehend:us-west-2:111122223333:topics-detection-job/1234abcd12ab34cd56ef1234567890ab *

*

* Returns a reference to this object so that method calls can be chained * together. *

* Constraints:
* Length: - 256
* Pattern: * arn:aws(-[^:]+)?:comprehend:[a-zA-Z0-9-]*:[0-9]{12}:[a-zA- * Z0-9-]{1,64} * /[a-zA-Z0-9](-*[a-zA-Z0-9])*((/dataset/[a-zA-Z0-9](-*[a-zA-Z0- * 9])*)|(/version/[a-zA-Z0-9](-*[a-zA-Z0-9])*))?
* * @param jobArn

* The Amazon Resource Name (ARN) of the topics detection job. It * is a unique, fully qualified identifier for the job. It * includes the Amazon Web Services account, Amazon Web Services * Region, and the job ID. The format of the ARN is as follows: *

*

* arn:<partition>:comprehend:<region>:<account-id>:topics-detection-job/<job-id> *

*

* The following is an example job ARN: *

*

* arn:aws:comprehend:us-west-2:111122223333:topics-detection-job/1234abcd12ab34cd56ef1234567890ab *

* @return A reference to this updated object so that method calls can be * chained together. */ public TopicsDetectionJobProperties withJobArn(String jobArn) { this.jobArn = jobArn; return this; } /** *

* The name of the topic detection job. *

*

* Constraints:
* Length: 1 - 256
* Pattern: ^([\p{L}\p{Z}\p{N}_.:/=+\-%@]*)$
* * @return

* The name of the topic detection job. *

*/ public String getJobName() { return jobName; } /** *

* The name of the topic detection job. *

*

* Constraints:
* Length: 1 - 256
* Pattern: ^([\p{L}\p{Z}\p{N}_.:/=+\-%@]*)$
* * @param jobName

* The name of the topic detection job. *

*/ public void setJobName(String jobName) { this.jobName = jobName; } /** *

* The name of the topic detection job. *

*

* Returns a reference to this object so that method calls can be chained * together. *

* Constraints:
* Length: 1 - 256
* Pattern: ^([\p{L}\p{Z}\p{N}_.:/=+\-%@]*)$
* * @param jobName

* The name of the topic detection job. *

* @return A reference to this updated object so that method calls can be * chained together. */ public TopicsDetectionJobProperties withJobName(String jobName) { this.jobName = jobName; return this; } /** *

* The current status of the topic detection job. If the status is * Failed, the reason for the failure is shown in the * Message field. *

*

* Constraints:
* Allowed Values: SUBMITTED, IN_PROGRESS, COMPLETED, FAILED, * STOP_REQUESTED, STOPPED * * @return

* The current status of the topic detection job. If the status is * Failed, the reason for the failure is shown in the * Message field. *

* @see JobStatus */ public String getJobStatus() { return jobStatus; } /** *

* The current status of the topic detection job. If the status is * Failed, the reason for the failure is shown in the * Message field. *

*

* Constraints:
* Allowed Values: SUBMITTED, IN_PROGRESS, COMPLETED, FAILED, * STOP_REQUESTED, STOPPED * * @param jobStatus

* The current status of the topic detection job. If the status * is Failed, the reason for the failure is shown in * the Message field. *

* @see JobStatus */ public void setJobStatus(String jobStatus) { this.jobStatus = jobStatus; } /** *

* The current status of the topic detection job. If the status is * Failed, the reason for the failure is shown in the * Message field. *

*

* Returns a reference to this object so that method calls can be chained * together. *

* Constraints:
* Allowed Values: SUBMITTED, IN_PROGRESS, COMPLETED, FAILED, * STOP_REQUESTED, STOPPED * * @param jobStatus

* The current status of the topic detection job. If the status * is Failed, the reason for the failure is shown in * the Message field. *

* @return A reference to this updated object so that method calls can be * chained together. * @see JobStatus */ public TopicsDetectionJobProperties withJobStatus(String jobStatus) { this.jobStatus = jobStatus; return this; } /** *

* The current status of the topic detection job. If the status is * Failed, the reason for the failure is shown in the * Message field. *

*

* Constraints:
* Allowed Values: SUBMITTED, IN_PROGRESS, COMPLETED, FAILED, * STOP_REQUESTED, STOPPED * * @param jobStatus

* The current status of the topic detection job. If the status * is Failed, the reason for the failure is shown in * the Message field. *

* @see JobStatus */ public void setJobStatus(JobStatus jobStatus) { this.jobStatus = jobStatus.toString(); } /** *

* The current status of the topic detection job. If the status is * Failed, the reason for the failure is shown in the * Message field. *

*

* Returns a reference to this object so that method calls can be chained * together. *

* Constraints:
* Allowed Values: SUBMITTED, IN_PROGRESS, COMPLETED, FAILED, * STOP_REQUESTED, STOPPED * * @param jobStatus

* The current status of the topic detection job. If the status * is Failed, the reason for the failure is shown in * the Message field. *

* @return A reference to this updated object so that method calls can be * chained together. * @see JobStatus */ public TopicsDetectionJobProperties withJobStatus(JobStatus jobStatus) { this.jobStatus = jobStatus.toString(); return this; } /** *

* A description for the status of a job. *

* * @return

* A description for the status of a job. *

*/ public String getMessage() { return message; } /** *

* A description for the status of a job. *

* * @param message

* A description for the status of a job. *

*/ public void setMessage(String message) { this.message = message; } /** *

* A description for the status of a job. *

*

* Returns a reference to this object so that method calls can be chained * together. * * @param message

* A description for the status of a job. *

* @return A reference to this updated object so that method calls can be * chained together. */ public TopicsDetectionJobProperties withMessage(String message) { this.message = message; return this; } /** *

* The time that the topic detection job was submitted for processing. *

* * @return

* The time that the topic detection job was submitted for * processing. *

*/ public java.util.Date getSubmitTime() { return submitTime; } /** *

* The time that the topic detection job was submitted for processing. *

* * @param submitTime

* The time that the topic detection job was submitted for * processing. *

*/ public void setSubmitTime(java.util.Date submitTime) { this.submitTime = submitTime; } /** *

* The time that the topic detection job was submitted for processing. *

*

* Returns a reference to this object so that method calls can be chained * together. * * @param submitTime

* The time that the topic detection job was submitted for * processing. *

* @return A reference to this updated object so that method calls can be * chained together. */ public TopicsDetectionJobProperties withSubmitTime(java.util.Date submitTime) { this.submitTime = submitTime; return this; } /** *

* The time that the topic detection job was completed. *

* * @return

* The time that the topic detection job was completed. *

*/ public java.util.Date getEndTime() { return endTime; } /** *

* The time that the topic detection job was completed. *

* * @param endTime

* The time that the topic detection job was completed. *

*/ public void setEndTime(java.util.Date endTime) { this.endTime = endTime; } /** *

* The time that the topic detection job was completed. *

*

* Returns a reference to this object so that method calls can be chained * together. * * @param endTime

* The time that the topic detection job was completed. *

* @return A reference to this updated object so that method calls can be * chained together. */ public TopicsDetectionJobProperties withEndTime(java.util.Date endTime) { this.endTime = endTime; return this; } /** *

* The input data configuration supplied when you created the topic * detection job. *

* * @return

* The input data configuration supplied when you created the topic * detection job. *

*/ public InputDataConfig getInputDataConfig() { return inputDataConfig; } /** *

* The input data configuration supplied when you created the topic * detection job. *

* * @param inputDataConfig

* The input data configuration supplied when you created the * topic detection job. *

*/ public void setInputDataConfig(InputDataConfig inputDataConfig) { this.inputDataConfig = inputDataConfig; } /** *

* The input data configuration supplied when you created the topic * detection job. *

*

* Returns a reference to this object so that method calls can be chained * together. * * @param inputDataConfig

* The input data configuration supplied when you created the * topic detection job. *

* @return A reference to this updated object so that method calls can be * chained together. */ public TopicsDetectionJobProperties withInputDataConfig(InputDataConfig inputDataConfig) { this.inputDataConfig = inputDataConfig; return this; } /** *

* The output data configuration supplied when you created the topic * detection job. *

* * @return

* The output data configuration supplied when you created the topic * detection job. *

*/ public OutputDataConfig getOutputDataConfig() { return outputDataConfig; } /** *

* The output data configuration supplied when you created the topic * detection job. *

* * @param outputDataConfig

* The output data configuration supplied when you created the * topic detection job. *

*/ public void setOutputDataConfig(OutputDataConfig outputDataConfig) { this.outputDataConfig = outputDataConfig; } /** *

* The output data configuration supplied when you created the topic * detection job. *

*

* Returns a reference to this object so that method calls can be chained * together. * * @param outputDataConfig

* The output data configuration supplied when you created the * topic detection job. *

* @return A reference to this updated object so that method calls can be * chained together. */ public TopicsDetectionJobProperties withOutputDataConfig(OutputDataConfig outputDataConfig) { this.outputDataConfig = outputDataConfig; return this; } /** *

* The number of topics to detect supplied when you created the topic * detection job. The default is 10. *

* * @return

* The number of topics to detect supplied when you created the * topic detection job. The default is 10. *

*/ public Integer getNumberOfTopics() { return numberOfTopics; } /** *

* The number of topics to detect supplied when you created the topic * detection job. The default is 10. *

* * @param numberOfTopics

* The number of topics to detect supplied when you created the * topic detection job. The default is 10. *

*/ public void setNumberOfTopics(Integer numberOfTopics) { this.numberOfTopics = numberOfTopics; } /** *

* The number of topics to detect supplied when you created the topic * detection job. The default is 10. *

*

* Returns a reference to this object so that method calls can be chained * together. * * @param numberOfTopics

* The number of topics to detect supplied when you created the * topic detection job. The default is 10. *

* @return A reference to this updated object so that method calls can be * chained together. */ public TopicsDetectionJobProperties withNumberOfTopics(Integer numberOfTopics) { this.numberOfTopics = numberOfTopics; return this; } /** *

* The Amazon Resource Name (ARN) of the IAM role that grants Amazon * Comprehend read access to your job data. *

*

* Constraints:
* Length: 20 - 2048
* Pattern: arn:aws(-[^:]+)?:iam::[0-9]{12}:role/.+
* * @return

* The Amazon Resource Name (ARN) of the IAM role that grants Amazon * Comprehend read access to your job data. *

*/ public String getDataAccessRoleArn() { return dataAccessRoleArn; } /** *

* The Amazon Resource Name (ARN) of the IAM role that grants Amazon * Comprehend read access to your job data. *

*

* Constraints:
* Length: 20 - 2048
* Pattern: arn:aws(-[^:]+)?:iam::[0-9]{12}:role/.+
* * @param dataAccessRoleArn

* The Amazon Resource Name (ARN) of the IAM role that grants * Amazon Comprehend read access to your job data. *

*/ public void setDataAccessRoleArn(String dataAccessRoleArn) { this.dataAccessRoleArn = dataAccessRoleArn; } /** *

* The Amazon Resource Name (ARN) of the IAM role that grants Amazon * Comprehend read access to your job data. *

*

* Returns a reference to this object so that method calls can be chained * together. *

* Constraints:
* Length: 20 - 2048
* Pattern: arn:aws(-[^:]+)?:iam::[0-9]{12}:role/.+
* * @param dataAccessRoleArn

* The Amazon Resource Name (ARN) of the IAM role that grants * Amazon Comprehend read access to your job data. *

* @return A reference to this updated object so that method calls can be * chained together. */ public TopicsDetectionJobProperties withDataAccessRoleArn(String dataAccessRoleArn) { this.dataAccessRoleArn = dataAccessRoleArn; return this; } /** *

* ID for the Amazon Web Services Key Management Service (KMS) key that * Amazon Comprehend uses to encrypt data on the storage volume attached to * the ML compute instance(s) that process the analysis job. The * VolumeKmsKeyId can be either of the following formats: *

* *

* Constraints:
* Length: - 2048
* Pattern: ^\p{ASCII}+$
* * @return

* ID for the Amazon Web Services Key Management Service (KMS) key * that Amazon Comprehend uses to encrypt data on the storage volume * attached to the ML compute instance(s) that process the analysis * job. The VolumeKmsKeyId can be either of the following formats: *

* */ public String getVolumeKmsKeyId() { return volumeKmsKeyId; } /** *

* ID for the Amazon Web Services Key Management Service (KMS) key that * Amazon Comprehend uses to encrypt data on the storage volume attached to * the ML compute instance(s) that process the analysis job. The * VolumeKmsKeyId can be either of the following formats: *

* *

* Constraints:
* Length: - 2048
* Pattern: ^\p{ASCII}+$
* * @param volumeKmsKeyId

* ID for the Amazon Web Services Key Management Service (KMS) * key that Amazon Comprehend uses to encrypt data on the storage * volume attached to the ML compute instance(s) that process the * analysis job. The VolumeKmsKeyId can be either of the * following formats: *

* */ public void setVolumeKmsKeyId(String volumeKmsKeyId) { this.volumeKmsKeyId = volumeKmsKeyId; } /** *

* ID for the Amazon Web Services Key Management Service (KMS) key that * Amazon Comprehend uses to encrypt data on the storage volume attached to * the ML compute instance(s) that process the analysis job. The * VolumeKmsKeyId can be either of the following formats: *

* *

* Returns a reference to this object so that method calls can be chained * together. *

* Constraints:
* Length: - 2048
* Pattern: ^\p{ASCII}+$
* * @param volumeKmsKeyId

* ID for the Amazon Web Services Key Management Service (KMS) * key that Amazon Comprehend uses to encrypt data on the storage * volume attached to the ML compute instance(s) that process the * analysis job. The VolumeKmsKeyId can be either of the * following formats: *

* * @return A reference to this updated object so that method calls can be * chained together. */ public TopicsDetectionJobProperties withVolumeKmsKeyId(String volumeKmsKeyId) { this.volumeKmsKeyId = volumeKmsKeyId; return this; } /** *

* Configuration parameters for a private Virtual Private Cloud (VPC) * containing the resources you are using for your topic detection job. For * more information, see Amazon VPC. *

* * @return

* Configuration parameters for a private Virtual Private Cloud * (VPC) containing the resources you are using for your topic * detection job. For more information, see Amazon VPC. *

*/ public VpcConfig getVpcConfig() { return vpcConfig; } /** *

* Configuration parameters for a private Virtual Private Cloud (VPC) * containing the resources you are using for your topic detection job. For * more information, see Amazon VPC. *

* * @param vpcConfig

* Configuration parameters for a private Virtual Private Cloud * (VPC) containing the resources you are using for your topic * detection job. For more information, see Amazon VPC. *

*/ public void setVpcConfig(VpcConfig vpcConfig) { this.vpcConfig = vpcConfig; } /** *

* Configuration parameters for a private Virtual Private Cloud (VPC) * containing the resources you are using for your topic detection job. For * more information, see Amazon VPC. *

*

* Returns a reference to this object so that method calls can be chained * together. * * @param vpcConfig

* Configuration parameters for a private Virtual Private Cloud * (VPC) containing the resources you are using for your topic * detection job. For more information, see Amazon VPC. *

* @return A reference to this updated object so that method calls can be * chained together. */ public TopicsDetectionJobProperties withVpcConfig(VpcConfig vpcConfig) { this.vpcConfig = vpcConfig; 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 (getJobId() != null) sb.append("JobId: " + getJobId() + ","); if (getJobArn() != null) sb.append("JobArn: " + getJobArn() + ","); if (getJobName() != null) sb.append("JobName: " + getJobName() + ","); if (getJobStatus() != null) sb.append("JobStatus: " + getJobStatus() + ","); if (getMessage() != null) sb.append("Message: " + getMessage() + ","); if (getSubmitTime() != null) sb.append("SubmitTime: " + getSubmitTime() + ","); if (getEndTime() != null) sb.append("EndTime: " + getEndTime() + ","); if (getInputDataConfig() != null) sb.append("InputDataConfig: " + getInputDataConfig() + ","); if (getOutputDataConfig() != null) sb.append("OutputDataConfig: " + getOutputDataConfig() + ","); if (getNumberOfTopics() != null) sb.append("NumberOfTopics: " + getNumberOfTopics() + ","); if (getDataAccessRoleArn() != null) sb.append("DataAccessRoleArn: " + getDataAccessRoleArn() + ","); if (getVolumeKmsKeyId() != null) sb.append("VolumeKmsKeyId: " + getVolumeKmsKeyId() + ","); if (getVpcConfig() != null) sb.append("VpcConfig: " + getVpcConfig()); sb.append("}"); return sb.toString(); } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getJobId() == null) ? 0 : getJobId().hashCode()); hashCode = prime * hashCode + ((getJobArn() == null) ? 0 : getJobArn().hashCode()); hashCode = prime * hashCode + ((getJobName() == null) ? 0 : getJobName().hashCode()); hashCode = prime * hashCode + ((getJobStatus() == null) ? 0 : getJobStatus().hashCode()); hashCode = prime * hashCode + ((getMessage() == null) ? 0 : getMessage().hashCode()); hashCode = prime * hashCode + ((getSubmitTime() == null) ? 0 : getSubmitTime().hashCode()); hashCode = prime * hashCode + ((getEndTime() == null) ? 0 : getEndTime().hashCode()); hashCode = prime * hashCode + ((getInputDataConfig() == null) ? 0 : getInputDataConfig().hashCode()); hashCode = prime * hashCode + ((getOutputDataConfig() == null) ? 0 : getOutputDataConfig().hashCode()); hashCode = prime * hashCode + ((getNumberOfTopics() == null) ? 0 : getNumberOfTopics().hashCode()); hashCode = prime * hashCode + ((getDataAccessRoleArn() == null) ? 0 : getDataAccessRoleArn().hashCode()); hashCode = prime * hashCode + ((getVolumeKmsKeyId() == null) ? 0 : getVolumeKmsKeyId().hashCode()); hashCode = prime * hashCode + ((getVpcConfig() == null) ? 0 : getVpcConfig().hashCode()); return hashCode; } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof TopicsDetectionJobProperties == false) return false; TopicsDetectionJobProperties other = (TopicsDetectionJobProperties) obj; if (other.getJobId() == null ^ this.getJobId() == null) return false; if (other.getJobId() != null && other.getJobId().equals(this.getJobId()) == false) return false; if (other.getJobArn() == null ^ this.getJobArn() == null) return false; if (other.getJobArn() != null && other.getJobArn().equals(this.getJobArn()) == false) return false; if (other.getJobName() == null ^ this.getJobName() == null) return false; if (other.getJobName() != null && other.getJobName().equals(this.getJobName()) == false) return false; if (other.getJobStatus() == null ^ this.getJobStatus() == null) return false; if (other.getJobStatus() != null && other.getJobStatus().equals(this.getJobStatus()) == false) return false; if (other.getMessage() == null ^ this.getMessage() == null) return false; if (other.getMessage() != null && other.getMessage().equals(this.getMessage()) == false) return false; if (other.getSubmitTime() == null ^ this.getSubmitTime() == null) return false; if (other.getSubmitTime() != null && other.getSubmitTime().equals(this.getSubmitTime()) == false) return false; if (other.getEndTime() == null ^ this.getEndTime() == null) return false; if (other.getEndTime() != null && other.getEndTime().equals(this.getEndTime()) == false) return false; if (other.getInputDataConfig() == null ^ this.getInputDataConfig() == null) return false; if (other.getInputDataConfig() != null && other.getInputDataConfig().equals(this.getInputDataConfig()) == false) return false; if (other.getOutputDataConfig() == null ^ this.getOutputDataConfig() == null) return false; if (other.getOutputDataConfig() != null && other.getOutputDataConfig().equals(this.getOutputDataConfig()) == false) return false; if (other.getNumberOfTopics() == null ^ this.getNumberOfTopics() == null) return false; if (other.getNumberOfTopics() != null && other.getNumberOfTopics().equals(this.getNumberOfTopics()) == false) return false; if (other.getDataAccessRoleArn() == null ^ this.getDataAccessRoleArn() == null) return false; if (other.getDataAccessRoleArn() != null && other.getDataAccessRoleArn().equals(this.getDataAccessRoleArn()) == false) return false; if (other.getVolumeKmsKeyId() == null ^ this.getVolumeKmsKeyId() == null) return false; if (other.getVolumeKmsKeyId() != null && other.getVolumeKmsKeyId().equals(this.getVolumeKmsKeyId()) == false) return false; if (other.getVpcConfig() == null ^ this.getVpcConfig() == null) return false; if (other.getVpcConfig() != null && other.getVpcConfig().equals(this.getVpcConfig()) == false) return false; return true; } }