/* * Copyright 2018-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.gluedatabrew.model; import java.io.Serializable; import javax.annotation.Generated; import com.amazonaws.protocol.StructuredPojo; import com.amazonaws.protocol.ProtocolMarshaller; /** *

* Represents a dataset that can be processed by DataBrew. *

* * @see AWS API * Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class Dataset implements Serializable, Cloneable, StructuredPojo { /** *

* The ID of the Amazon Web Services account that owns the dataset. *

*/ private String accountId; /** *

* The Amazon Resource Name (ARN) of the user who created the dataset. *

*/ private String createdBy; /** *

* The date and time that the dataset was created. *

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

* The unique name of the dataset. *

*/ private String name; /** *

* The file format of a dataset that is created from an Amazon S3 file or folder. *

*/ private String format; /** *

* A set of options that define how DataBrew interprets the data in the dataset. *

*/ private FormatOptions formatOptions; /** *

* Information on how DataBrew can find the dataset, in either the Glue Data Catalog or Amazon S3. *

*/ private Input input; /** *

* The last modification date and time of the dataset. *

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

* The Amazon Resource Name (ARN) of the user who last modified the dataset. *

*/ private String lastModifiedBy; /** *

* The location of the data for the dataset, either Amazon S3 or the Glue Data Catalog. *

*/ private String source; /** *

* A set of options that defines how DataBrew interprets an Amazon S3 path of the dataset. *

*/ private PathOptions pathOptions; /** *

* Metadata tags that have been applied to the dataset. *

*/ private java.util.Map tags; /** *

* The unique Amazon Resource Name (ARN) for the dataset. *

*/ private String resourceArn; /** *

* The ID of the Amazon Web Services account that owns the dataset. *

* * @param accountId * The ID of the Amazon Web Services account that owns the dataset. */ public void setAccountId(String accountId) { this.accountId = accountId; } /** *

* The ID of the Amazon Web Services account that owns the dataset. *

* * @return The ID of the Amazon Web Services account that owns the dataset. */ public String getAccountId() { return this.accountId; } /** *

* The ID of the Amazon Web Services account that owns the dataset. *

* * @param accountId * The ID of the Amazon Web Services account that owns the dataset. * @return Returns a reference to this object so that method calls can be chained together. */ public Dataset withAccountId(String accountId) { setAccountId(accountId); return this; } /** *

* The Amazon Resource Name (ARN) of the user who created the dataset. *

* * @param createdBy * The Amazon Resource Name (ARN) of the user who created the dataset. */ public void setCreatedBy(String createdBy) { this.createdBy = createdBy; } /** *

* The Amazon Resource Name (ARN) of the user who created the dataset. *

* * @return The Amazon Resource Name (ARN) of the user who created the dataset. */ public String getCreatedBy() { return this.createdBy; } /** *

* The Amazon Resource Name (ARN) of the user who created the dataset. *

* * @param createdBy * The Amazon Resource Name (ARN) of the user who created the dataset. * @return Returns a reference to this object so that method calls can be chained together. */ public Dataset withCreatedBy(String createdBy) { setCreatedBy(createdBy); return this; } /** *

* The date and time that the dataset was created. *

* * @param createDate * The date and time that the dataset was created. */ public void setCreateDate(java.util.Date createDate) { this.createDate = createDate; } /** *

* The date and time that the dataset was created. *

* * @return The date and time that the dataset was created. */ public java.util.Date getCreateDate() { return this.createDate; } /** *

* The date and time that the dataset was created. *

* * @param createDate * The date and time that the dataset was created. * @return Returns a reference to this object so that method calls can be chained together. */ public Dataset withCreateDate(java.util.Date createDate) { setCreateDate(createDate); return this; } /** *

* The unique name of the dataset. *

* * @param name * The unique name of the dataset. */ public void setName(String name) { this.name = name; } /** *

* The unique name of the dataset. *

* * @return The unique name of the dataset. */ public String getName() { return this.name; } /** *

* The unique name of the dataset. *

* * @param name * The unique name of the dataset. * @return Returns a reference to this object so that method calls can be chained together. */ public Dataset withName(String name) { setName(name); return this; } /** *

* The file format of a dataset that is created from an Amazon S3 file or folder. *

* * @param format * The file format of a dataset that is created from an Amazon S3 file or folder. * @see InputFormat */ public void setFormat(String format) { this.format = format; } /** *

* The file format of a dataset that is created from an Amazon S3 file or folder. *

* * @return The file format of a dataset that is created from an Amazon S3 file or folder. * @see InputFormat */ public String getFormat() { return this.format; } /** *

* The file format of a dataset that is created from an Amazon S3 file or folder. *

* * @param format * The file format of a dataset that is created from an Amazon S3 file or folder. * @return Returns a reference to this object so that method calls can be chained together. * @see InputFormat */ public Dataset withFormat(String format) { setFormat(format); return this; } /** *

* The file format of a dataset that is created from an Amazon S3 file or folder. *

* * @param format * The file format of a dataset that is created from an Amazon S3 file or folder. * @return Returns a reference to this object so that method calls can be chained together. * @see InputFormat */ public Dataset withFormat(InputFormat format) { this.format = format.toString(); return this; } /** *

* A set of options that define how DataBrew interprets the data in the dataset. *

* * @param formatOptions * A set of options that define how DataBrew interprets the data in the dataset. */ public void setFormatOptions(FormatOptions formatOptions) { this.formatOptions = formatOptions; } /** *

* A set of options that define how DataBrew interprets the data in the dataset. *

* * @return A set of options that define how DataBrew interprets the data in the dataset. */ public FormatOptions getFormatOptions() { return this.formatOptions; } /** *

* A set of options that define how DataBrew interprets the data in the dataset. *

* * @param formatOptions * A set of options that define how DataBrew interprets the data in the dataset. * @return Returns a reference to this object so that method calls can be chained together. */ public Dataset withFormatOptions(FormatOptions formatOptions) { setFormatOptions(formatOptions); return this; } /** *

* Information on how DataBrew can find the dataset, in either the Glue Data Catalog or Amazon S3. *

* * @param input * Information on how DataBrew can find the dataset, in either the Glue Data Catalog or Amazon S3. */ public void setInput(Input input) { this.input = input; } /** *

* Information on how DataBrew can find the dataset, in either the Glue Data Catalog or Amazon S3. *

* * @return Information on how DataBrew can find the dataset, in either the Glue Data Catalog or Amazon S3. */ public Input getInput() { return this.input; } /** *

* Information on how DataBrew can find the dataset, in either the Glue Data Catalog or Amazon S3. *

* * @param input * Information on how DataBrew can find the dataset, in either the Glue Data Catalog or Amazon S3. * @return Returns a reference to this object so that method calls can be chained together. */ public Dataset withInput(Input input) { setInput(input); return this; } /** *

* The last modification date and time of the dataset. *

* * @param lastModifiedDate * The last modification date and time of the dataset. */ public void setLastModifiedDate(java.util.Date lastModifiedDate) { this.lastModifiedDate = lastModifiedDate; } /** *

* The last modification date and time of the dataset. *

* * @return The last modification date and time of the dataset. */ public java.util.Date getLastModifiedDate() { return this.lastModifiedDate; } /** *

* The last modification date and time of the dataset. *

* * @param lastModifiedDate * The last modification date and time of the dataset. * @return Returns a reference to this object so that method calls can be chained together. */ public Dataset withLastModifiedDate(java.util.Date lastModifiedDate) { setLastModifiedDate(lastModifiedDate); return this; } /** *

* The Amazon Resource Name (ARN) of the user who last modified the dataset. *

* * @param lastModifiedBy * The Amazon Resource Name (ARN) of the user who last modified the dataset. */ public void setLastModifiedBy(String lastModifiedBy) { this.lastModifiedBy = lastModifiedBy; } /** *

* The Amazon Resource Name (ARN) of the user who last modified the dataset. *

* * @return The Amazon Resource Name (ARN) of the user who last modified the dataset. */ public String getLastModifiedBy() { return this.lastModifiedBy; } /** *

* The Amazon Resource Name (ARN) of the user who last modified the dataset. *

* * @param lastModifiedBy * The Amazon Resource Name (ARN) of the user who last modified the dataset. * @return Returns a reference to this object so that method calls can be chained together. */ public Dataset withLastModifiedBy(String lastModifiedBy) { setLastModifiedBy(lastModifiedBy); return this; } /** *

* The location of the data for the dataset, either Amazon S3 or the Glue Data Catalog. *

* * @param source * The location of the data for the dataset, either Amazon S3 or the Glue Data Catalog. * @see Source */ public void setSource(String source) { this.source = source; } /** *

* The location of the data for the dataset, either Amazon S3 or the Glue Data Catalog. *

* * @return The location of the data for the dataset, either Amazon S3 or the Glue Data Catalog. * @see Source */ public String getSource() { return this.source; } /** *

* The location of the data for the dataset, either Amazon S3 or the Glue Data Catalog. *

* * @param source * The location of the data for the dataset, either Amazon S3 or the Glue Data Catalog. * @return Returns a reference to this object so that method calls can be chained together. * @see Source */ public Dataset withSource(String source) { setSource(source); return this; } /** *

* The location of the data for the dataset, either Amazon S3 or the Glue Data Catalog. *

* * @param source * The location of the data for the dataset, either Amazon S3 or the Glue Data Catalog. * @return Returns a reference to this object so that method calls can be chained together. * @see Source */ public Dataset withSource(Source source) { this.source = source.toString(); return this; } /** *

* A set of options that defines how DataBrew interprets an Amazon S3 path of the dataset. *

* * @param pathOptions * A set of options that defines how DataBrew interprets an Amazon S3 path of the dataset. */ public void setPathOptions(PathOptions pathOptions) { this.pathOptions = pathOptions; } /** *

* A set of options that defines how DataBrew interprets an Amazon S3 path of the dataset. *

* * @return A set of options that defines how DataBrew interprets an Amazon S3 path of the dataset. */ public PathOptions getPathOptions() { return this.pathOptions; } /** *

* A set of options that defines how DataBrew interprets an Amazon S3 path of the dataset. *

* * @param pathOptions * A set of options that defines how DataBrew interprets an Amazon S3 path of the dataset. * @return Returns a reference to this object so that method calls can be chained together. */ public Dataset withPathOptions(PathOptions pathOptions) { setPathOptions(pathOptions); return this; } /** *

* Metadata tags that have been applied to the dataset. *

* * @return Metadata tags that have been applied to the dataset. */ public java.util.Map getTags() { return tags; } /** *

* Metadata tags that have been applied to the dataset. *

* * @param tags * Metadata tags that have been applied to the dataset. */ public void setTags(java.util.Map tags) { this.tags = tags; } /** *

* Metadata tags that have been applied to the dataset. *

* * @param tags * Metadata tags that have been applied to the dataset. * @return Returns a reference to this object so that method calls can be chained together. */ public Dataset withTags(java.util.Map tags) { setTags(tags); return this; } /** * Add a single Tags entry * * @see Dataset#withTags * @returns a reference to this object so that method calls can be chained together. */ public Dataset 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 Dataset clearTagsEntries() { this.tags = null; return this; } /** *

* The unique Amazon Resource Name (ARN) for the dataset. *

* * @param resourceArn * The unique Amazon Resource Name (ARN) for the dataset. */ public void setResourceArn(String resourceArn) { this.resourceArn = resourceArn; } /** *

* The unique Amazon Resource Name (ARN) for the dataset. *

* * @return The unique Amazon Resource Name (ARN) for the dataset. */ public String getResourceArn() { return this.resourceArn; } /** *

* The unique Amazon Resource Name (ARN) for the dataset. *

* * @param resourceArn * The unique Amazon Resource Name (ARN) for the dataset. * @return Returns a reference to this object so that method calls can be chained together. */ public Dataset withResourceArn(String resourceArn) { setResourceArn(resourceArn); 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 (getAccountId() != null) sb.append("AccountId: ").append(getAccountId()).append(","); if (getCreatedBy() != null) sb.append("CreatedBy: ").append(getCreatedBy()).append(","); if (getCreateDate() != null) sb.append("CreateDate: ").append(getCreateDate()).append(","); if (getName() != null) sb.append("Name: ").append(getName()).append(","); if (getFormat() != null) sb.append("Format: ").append(getFormat()).append(","); if (getFormatOptions() != null) sb.append("FormatOptions: ").append(getFormatOptions()).append(","); if (getInput() != null) sb.append("Input: ").append(getInput()).append(","); if (getLastModifiedDate() != null) sb.append("LastModifiedDate: ").append(getLastModifiedDate()).append(","); if (getLastModifiedBy() != null) sb.append("LastModifiedBy: ").append(getLastModifiedBy()).append(","); if (getSource() != null) sb.append("Source: ").append(getSource()).append(","); if (getPathOptions() != null) sb.append("PathOptions: ").append(getPathOptions()).append(","); if (getTags() != null) sb.append("Tags: ").append(getTags()).append(","); if (getResourceArn() != null) sb.append("ResourceArn: ").append(getResourceArn()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof Dataset == false) return false; Dataset other = (Dataset) obj; if (other.getAccountId() == null ^ this.getAccountId() == null) return false; if (other.getAccountId() != null && other.getAccountId().equals(this.getAccountId()) == false) return false; if (other.getCreatedBy() == null ^ this.getCreatedBy() == null) return false; if (other.getCreatedBy() != null && other.getCreatedBy().equals(this.getCreatedBy()) == false) return false; if (other.getCreateDate() == null ^ this.getCreateDate() == null) return false; if (other.getCreateDate() != null && other.getCreateDate().equals(this.getCreateDate()) == false) return false; if (other.getName() == null ^ this.getName() == null) return false; if (other.getName() != null && other.getName().equals(this.getName()) == false) return false; if (other.getFormat() == null ^ this.getFormat() == null) return false; if (other.getFormat() != null && other.getFormat().equals(this.getFormat()) == false) return false; if (other.getFormatOptions() == null ^ this.getFormatOptions() == null) return false; if (other.getFormatOptions() != null && other.getFormatOptions().equals(this.getFormatOptions()) == false) return false; if (other.getInput() == null ^ this.getInput() == null) return false; if (other.getInput() != null && other.getInput().equals(this.getInput()) == false) return false; if (other.getLastModifiedDate() == null ^ this.getLastModifiedDate() == null) return false; if (other.getLastModifiedDate() != null && other.getLastModifiedDate().equals(this.getLastModifiedDate()) == false) return false; if (other.getLastModifiedBy() == null ^ this.getLastModifiedBy() == null) return false; if (other.getLastModifiedBy() != null && other.getLastModifiedBy().equals(this.getLastModifiedBy()) == false) return false; if (other.getSource() == null ^ this.getSource() == null) return false; if (other.getSource() != null && other.getSource().equals(this.getSource()) == false) return false; if (other.getPathOptions() == null ^ this.getPathOptions() == null) return false; if (other.getPathOptions() != null && other.getPathOptions().equals(this.getPathOptions()) == false) return false; if (other.getTags() == null ^ this.getTags() == null) return false; if (other.getTags() != null && other.getTags().equals(this.getTags()) == false) return false; if (other.getResourceArn() == null ^ this.getResourceArn() == null) return false; if (other.getResourceArn() != null && other.getResourceArn().equals(this.getResourceArn()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getAccountId() == null) ? 0 : getAccountId().hashCode()); hashCode = prime * hashCode + ((getCreatedBy() == null) ? 0 : getCreatedBy().hashCode()); hashCode = prime * hashCode + ((getCreateDate() == null) ? 0 : getCreateDate().hashCode()); hashCode = prime * hashCode + ((getName() == null) ? 0 : getName().hashCode()); hashCode = prime * hashCode + ((getFormat() == null) ? 0 : getFormat().hashCode()); hashCode = prime * hashCode + ((getFormatOptions() == null) ? 0 : getFormatOptions().hashCode()); hashCode = prime * hashCode + ((getInput() == null) ? 0 : getInput().hashCode()); hashCode = prime * hashCode + ((getLastModifiedDate() == null) ? 0 : getLastModifiedDate().hashCode()); hashCode = prime * hashCode + ((getLastModifiedBy() == null) ? 0 : getLastModifiedBy().hashCode()); hashCode = prime * hashCode + ((getSource() == null) ? 0 : getSource().hashCode()); hashCode = prime * hashCode + ((getPathOptions() == null) ? 0 : getPathOptions().hashCode()); hashCode = prime * hashCode + ((getTags() == null) ? 0 : getTags().hashCode()); hashCode = prime * hashCode + ((getResourceArn() == null) ? 0 : getResourceArn().hashCode()); return hashCode; } @Override public Dataset clone() { try { return (Dataset) 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.gluedatabrew.model.transform.DatasetMarshaller.getInstance().marshall(this, protocolMarshaller); } }