
shiver.me.timbers.aws.glue.PartitionPartitionInput Maven / Gradle / Ivy
package shiver.me.timbers.aws.glue;
import java.util.ArrayList;
import java.util.List;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonPropertyDescription;
import com.fasterxml.jackson.annotation.JsonPropertyOrder;
import org.apache.commons.lang.builder.EqualsBuilder;
import org.apache.commons.lang.builder.HashCodeBuilder;
import org.apache.commons.lang.builder.ToStringBuilder;
import shiver.me.timbers.aws.Property;
/**
* PartitionPartitionInput
*
* http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-glue-partition-partitioninput.html
*
*/
@JsonInclude(JsonInclude.Include.NON_EMPTY)
@JsonPropertyOrder({
"Parameters",
"StorageDescriptor",
"Values"
})
public class PartitionPartitionInput implements Property
{
/**
* http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-glue-partition-partitioninput.html#cfn-glue-partition-partitioninput-parameters
*
*/
@JsonProperty("Parameters")
@JsonPropertyDescription("http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-glue-partition-partitioninput.html#cfn-glue-partition-partitioninput-parameters")
private Object parameters;
/**
* PartitionStorageDescriptor
*
* http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-glue-partition-storagedescriptor.html
*
*/
@JsonProperty("StorageDescriptor")
@JsonPropertyDescription("http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-glue-partition-storagedescriptor.html")
private Property storageDescriptor;
/**
* http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-glue-partition-partitioninput.html#cfn-glue-partition-partitioninput-values
*
*/
@JsonProperty("Values")
@JsonPropertyDescription("http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-glue-partition-partitioninput.html#cfn-glue-partition-partitioninput-values")
private List values = new ArrayList();
/**
* http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-glue-partition-partitioninput.html#cfn-glue-partition-partitioninput-parameters
*
*/
@JsonIgnore
public Object getParameters() {
return parameters;
}
/**
* http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-glue-partition-partitioninput.html#cfn-glue-partition-partitioninput-parameters
*
*/
@JsonIgnore
public void setParameters(Object parameters) {
this.parameters = parameters;
}
public PartitionPartitionInput withParameters(Object parameters) {
this.parameters = parameters;
return this;
}
/**
* PartitionStorageDescriptor
*
* http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-glue-partition-storagedescriptor.html
*
*/
@JsonIgnore
public Property getStorageDescriptor() {
return storageDescriptor;
}
/**
* PartitionStorageDescriptor
*
* http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-glue-partition-storagedescriptor.html
*
*/
@JsonIgnore
public void setStorageDescriptor(Property storageDescriptor) {
this.storageDescriptor = storageDescriptor;
}
public PartitionPartitionInput withStorageDescriptor(Property storageDescriptor) {
this.storageDescriptor = storageDescriptor;
return this;
}
/**
* http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-glue-partition-partitioninput.html#cfn-glue-partition-partitioninput-values
*
*/
@JsonIgnore
public List getValues() {
return values;
}
/**
* http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-glue-partition-partitioninput.html#cfn-glue-partition-partitioninput-values
*
*/
@JsonIgnore
public void setValues(List values) {
this.values = values;
}
public PartitionPartitionInput withValues(List values) {
this.values = values;
return this;
}
@Override
public String toString() {
return new ToStringBuilder(this).append("parameters", parameters).append("storageDescriptor", storageDescriptor).append("values", values).toString();
}
@Override
public int hashCode() {
return new HashCodeBuilder().append(storageDescriptor).append(parameters).append(values).toHashCode();
}
@Override
public boolean equals(Object other) {
if (other == this) {
return true;
}
if ((other instanceof PartitionPartitionInput) == false) {
return false;
}
PartitionPartitionInput rhs = ((PartitionPartitionInput) other);
return new EqualsBuilder().append(storageDescriptor, rhs.storageDescriptor).append(parameters, rhs.parameters).append(values, rhs.values).isEquals();
}
}