All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.amazonaws.services.finspacedata.model.CreateDataViewRequest Maven / Gradle / Ivy

/*
 * 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.finspacedata.model;

import java.io.Serializable;
import javax.annotation.Generated;

import com.amazonaws.AmazonWebServiceRequest;

/**
 * Request for creating a data view.
 * 
 * @see AWS API
 *      Documentation
 */
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class CreateDataViewRequest extends com.amazonaws.AmazonWebServiceRequest implements Serializable, Cloneable {

    /**
     * 

* A token that ensures idempotency. This token expires in 10 minutes. *

*/ private String clientToken; /** *

* The unique Dataset identifier that is used to create a Dataview. *

*/ private String datasetId; /** *

* Flag to indicate Dataview should be updated automatically. *

*/ private Boolean autoUpdate; /** *

* Columns to be used for sorting the data. *

*/ private java.util.List sortColumns; /** *

* Ordered set of column names used to partition data. *

*/ private java.util.List partitionColumns; /** *

* Beginning time to use for the Dataview. The value is determined as epoch time in milliseconds. For example, the * value for Monday, November 1, 2021 12:00:00 PM UTC is specified as 1635768000000. *

*/ private Long asOfTimestamp; /** *

* Options that define the destination type for the Dataview. *

*/ private DataViewDestinationTypeParams destinationTypeParams; /** *

* A token that ensures idempotency. This token expires in 10 minutes. *

* * @param clientToken * A token that ensures idempotency. This token expires in 10 minutes. */ public void setClientToken(String clientToken) { this.clientToken = clientToken; } /** *

* A token that ensures idempotency. This token expires in 10 minutes. *

* * @return A token that ensures idempotency. This token expires in 10 minutes. */ public String getClientToken() { return this.clientToken; } /** *

* A token that ensures idempotency. This token expires in 10 minutes. *

* * @param clientToken * A token that ensures idempotency. This token expires in 10 minutes. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDataViewRequest withClientToken(String clientToken) { setClientToken(clientToken); return this; } /** *

* The unique Dataset identifier that is used to create a Dataview. *

* * @param datasetId * The unique Dataset identifier that is used to create a Dataview. */ public void setDatasetId(String datasetId) { this.datasetId = datasetId; } /** *

* The unique Dataset identifier that is used to create a Dataview. *

* * @return The unique Dataset identifier that is used to create a Dataview. */ public String getDatasetId() { return this.datasetId; } /** *

* The unique Dataset identifier that is used to create a Dataview. *

* * @param datasetId * The unique Dataset identifier that is used to create a Dataview. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDataViewRequest withDatasetId(String datasetId) { setDatasetId(datasetId); return this; } /** *

* Flag to indicate Dataview should be updated automatically. *

* * @param autoUpdate * Flag to indicate Dataview should be updated automatically. */ public void setAutoUpdate(Boolean autoUpdate) { this.autoUpdate = autoUpdate; } /** *

* Flag to indicate Dataview should be updated automatically. *

* * @return Flag to indicate Dataview should be updated automatically. */ public Boolean getAutoUpdate() { return this.autoUpdate; } /** *

* Flag to indicate Dataview should be updated automatically. *

* * @param autoUpdate * Flag to indicate Dataview should be updated automatically. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDataViewRequest withAutoUpdate(Boolean autoUpdate) { setAutoUpdate(autoUpdate); return this; } /** *

* Flag to indicate Dataview should be updated automatically. *

* * @return Flag to indicate Dataview should be updated automatically. */ public Boolean isAutoUpdate() { return this.autoUpdate; } /** *

* Columns to be used for sorting the data. *

* * @return Columns to be used for sorting the data. */ public java.util.List getSortColumns() { return sortColumns; } /** *

* Columns to be used for sorting the data. *

* * @param sortColumns * Columns to be used for sorting the data. */ public void setSortColumns(java.util.Collection sortColumns) { if (sortColumns == null) { this.sortColumns = null; return; } this.sortColumns = new java.util.ArrayList(sortColumns); } /** *

* Columns to be used for sorting the data. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setSortColumns(java.util.Collection)} or {@link #withSortColumns(java.util.Collection)} if you want to * override the existing values. *

* * @param sortColumns * Columns to be used for sorting the data. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDataViewRequest withSortColumns(String... sortColumns) { if (this.sortColumns == null) { setSortColumns(new java.util.ArrayList(sortColumns.length)); } for (String ele : sortColumns) { this.sortColumns.add(ele); } return this; } /** *

* Columns to be used for sorting the data. *

* * @param sortColumns * Columns to be used for sorting the data. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDataViewRequest withSortColumns(java.util.Collection sortColumns) { setSortColumns(sortColumns); return this; } /** *

* Ordered set of column names used to partition data. *

* * @return Ordered set of column names used to partition data. */ public java.util.List getPartitionColumns() { return partitionColumns; } /** *

* Ordered set of column names used to partition data. *

* * @param partitionColumns * Ordered set of column names used to partition data. */ public void setPartitionColumns(java.util.Collection partitionColumns) { if (partitionColumns == null) { this.partitionColumns = null; return; } this.partitionColumns = new java.util.ArrayList(partitionColumns); } /** *

* Ordered set of column names used to partition data. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setPartitionColumns(java.util.Collection)} or {@link #withPartitionColumns(java.util.Collection)} if you * want to override the existing values. *

* * @param partitionColumns * Ordered set of column names used to partition data. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDataViewRequest withPartitionColumns(String... partitionColumns) { if (this.partitionColumns == null) { setPartitionColumns(new java.util.ArrayList(partitionColumns.length)); } for (String ele : partitionColumns) { this.partitionColumns.add(ele); } return this; } /** *

* Ordered set of column names used to partition data. *

* * @param partitionColumns * Ordered set of column names used to partition data. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDataViewRequest withPartitionColumns(java.util.Collection partitionColumns) { setPartitionColumns(partitionColumns); return this; } /** *

* Beginning time to use for the Dataview. The value is determined as epoch time in milliseconds. For example, the * value for Monday, November 1, 2021 12:00:00 PM UTC is specified as 1635768000000. *

* * @param asOfTimestamp * Beginning time to use for the Dataview. The value is determined as epoch time in milliseconds. For * example, the value for Monday, November 1, 2021 12:00:00 PM UTC is specified as 1635768000000. */ public void setAsOfTimestamp(Long asOfTimestamp) { this.asOfTimestamp = asOfTimestamp; } /** *

* Beginning time to use for the Dataview. The value is determined as epoch time in milliseconds. For example, the * value for Monday, November 1, 2021 12:00:00 PM UTC is specified as 1635768000000. *

* * @return Beginning time to use for the Dataview. The value is determined as epoch time in milliseconds. For * example, the value for Monday, November 1, 2021 12:00:00 PM UTC is specified as 1635768000000. */ public Long getAsOfTimestamp() { return this.asOfTimestamp; } /** *

* Beginning time to use for the Dataview. The value is determined as epoch time in milliseconds. For example, the * value for Monday, November 1, 2021 12:00:00 PM UTC is specified as 1635768000000. *

* * @param asOfTimestamp * Beginning time to use for the Dataview. The value is determined as epoch time in milliseconds. For * example, the value for Monday, November 1, 2021 12:00:00 PM UTC is specified as 1635768000000. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDataViewRequest withAsOfTimestamp(Long asOfTimestamp) { setAsOfTimestamp(asOfTimestamp); return this; } /** *

* Options that define the destination type for the Dataview. *

* * @param destinationTypeParams * Options that define the destination type for the Dataview. */ public void setDestinationTypeParams(DataViewDestinationTypeParams destinationTypeParams) { this.destinationTypeParams = destinationTypeParams; } /** *

* Options that define the destination type for the Dataview. *

* * @return Options that define the destination type for the Dataview. */ public DataViewDestinationTypeParams getDestinationTypeParams() { return this.destinationTypeParams; } /** *

* Options that define the destination type for the Dataview. *

* * @param destinationTypeParams * Options that define the destination type for the Dataview. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDataViewRequest withDestinationTypeParams(DataViewDestinationTypeParams destinationTypeParams) { setDestinationTypeParams(destinationTypeParams); 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 (getClientToken() != null) sb.append("ClientToken: ").append(getClientToken()).append(","); if (getDatasetId() != null) sb.append("DatasetId: ").append(getDatasetId()).append(","); if (getAutoUpdate() != null) sb.append("AutoUpdate: ").append(getAutoUpdate()).append(","); if (getSortColumns() != null) sb.append("SortColumns: ").append(getSortColumns()).append(","); if (getPartitionColumns() != null) sb.append("PartitionColumns: ").append(getPartitionColumns()).append(","); if (getAsOfTimestamp() != null) sb.append("AsOfTimestamp: ").append(getAsOfTimestamp()).append(","); if (getDestinationTypeParams() != null) sb.append("DestinationTypeParams: ").append(getDestinationTypeParams()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof CreateDataViewRequest == false) return false; CreateDataViewRequest other = (CreateDataViewRequest) obj; if (other.getClientToken() == null ^ this.getClientToken() == null) return false; if (other.getClientToken() != null && other.getClientToken().equals(this.getClientToken()) == false) return false; if (other.getDatasetId() == null ^ this.getDatasetId() == null) return false; if (other.getDatasetId() != null && other.getDatasetId().equals(this.getDatasetId()) == false) return false; if (other.getAutoUpdate() == null ^ this.getAutoUpdate() == null) return false; if (other.getAutoUpdate() != null && other.getAutoUpdate().equals(this.getAutoUpdate()) == false) return false; if (other.getSortColumns() == null ^ this.getSortColumns() == null) return false; if (other.getSortColumns() != null && other.getSortColumns().equals(this.getSortColumns()) == false) return false; if (other.getPartitionColumns() == null ^ this.getPartitionColumns() == null) return false; if (other.getPartitionColumns() != null && other.getPartitionColumns().equals(this.getPartitionColumns()) == false) return false; if (other.getAsOfTimestamp() == null ^ this.getAsOfTimestamp() == null) return false; if (other.getAsOfTimestamp() != null && other.getAsOfTimestamp().equals(this.getAsOfTimestamp()) == false) return false; if (other.getDestinationTypeParams() == null ^ this.getDestinationTypeParams() == null) return false; if (other.getDestinationTypeParams() != null && other.getDestinationTypeParams().equals(this.getDestinationTypeParams()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getClientToken() == null) ? 0 : getClientToken().hashCode()); hashCode = prime * hashCode + ((getDatasetId() == null) ? 0 : getDatasetId().hashCode()); hashCode = prime * hashCode + ((getAutoUpdate() == null) ? 0 : getAutoUpdate().hashCode()); hashCode = prime * hashCode + ((getSortColumns() == null) ? 0 : getSortColumns().hashCode()); hashCode = prime * hashCode + ((getPartitionColumns() == null) ? 0 : getPartitionColumns().hashCode()); hashCode = prime * hashCode + ((getAsOfTimestamp() == null) ? 0 : getAsOfTimestamp().hashCode()); hashCode = prime * hashCode + ((getDestinationTypeParams() == null) ? 0 : getDestinationTypeParams().hashCode()); return hashCode; } @Override public CreateDataViewRequest clone() { return (CreateDataViewRequest) super.clone(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy