com.amazonaws.services.rds.model.ValidStorageOptions 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.rds.model;
import java.io.Serializable;
import javax.annotation.Generated;
/**
*
* Information about valid modifications that you can make to your DB instance. Contains the result of a successful call
* to the DescribeValidDBInstanceModifications
action.
*
*
* @see AWS API
* Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class ValidStorageOptions implements Serializable, Cloneable {
/**
*
* The valid storage types for your DB instance. For example, gp2, io1.
*
*/
private String storageType;
/**
*
* The valid range of storage in gibibytes (GiB). For example, 100 to 16384.
*
*/
private com.amazonaws.internal.SdkInternalList storageSize;
/**
*
* The valid range of provisioned IOPS. For example, 1000-20000.
*
*/
private com.amazonaws.internal.SdkInternalList provisionedIops;
/**
*
* The valid range of Provisioned IOPS to gibibytes of storage multiplier. For example, 3-10, which means that
* provisioned IOPS can be between 3 and 10 times storage.
*
*/
private com.amazonaws.internal.SdkInternalList iopsToStorageRatio;
/**
*
* Whether or not Amazon RDS can automatically scale storage for DB instances that use the new instance class.
*
*/
private Boolean supportsStorageAutoscaling;
/**
*
* The valid storage types for your DB instance. For example, gp2, io1.
*
*
* @param storageType
* The valid storage types for your DB instance. For example, gp2, io1.
*/
public void setStorageType(String storageType) {
this.storageType = storageType;
}
/**
*
* The valid storage types for your DB instance. For example, gp2, io1.
*
*
* @return The valid storage types for your DB instance. For example, gp2, io1.
*/
public String getStorageType() {
return this.storageType;
}
/**
*
* The valid storage types for your DB instance. For example, gp2, io1.
*
*
* @param storageType
* The valid storage types for your DB instance. For example, gp2, io1.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ValidStorageOptions withStorageType(String storageType) {
setStorageType(storageType);
return this;
}
/**
*
* The valid range of storage in gibibytes (GiB). For example, 100 to 16384.
*
*
* @return The valid range of storage in gibibytes (GiB). For example, 100 to 16384.
*/
public java.util.List getStorageSize() {
if (storageSize == null) {
storageSize = new com.amazonaws.internal.SdkInternalList();
}
return storageSize;
}
/**
*
* The valid range of storage in gibibytes (GiB). For example, 100 to 16384.
*
*
* @param storageSize
* The valid range of storage in gibibytes (GiB). For example, 100 to 16384.
*/
public void setStorageSize(java.util.Collection storageSize) {
if (storageSize == null) {
this.storageSize = null;
return;
}
this.storageSize = new com.amazonaws.internal.SdkInternalList(storageSize);
}
/**
*
* The valid range of storage in gibibytes (GiB). For example, 100 to 16384.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setStorageSize(java.util.Collection)} or {@link #withStorageSize(java.util.Collection)} if you want to
* override the existing values.
*
*
* @param storageSize
* The valid range of storage in gibibytes (GiB). For example, 100 to 16384.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ValidStorageOptions withStorageSize(Range... storageSize) {
if (this.storageSize == null) {
setStorageSize(new com.amazonaws.internal.SdkInternalList(storageSize.length));
}
for (Range ele : storageSize) {
this.storageSize.add(ele);
}
return this;
}
/**
*
* The valid range of storage in gibibytes (GiB). For example, 100 to 16384.
*
*
* @param storageSize
* The valid range of storage in gibibytes (GiB). For example, 100 to 16384.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ValidStorageOptions withStorageSize(java.util.Collection storageSize) {
setStorageSize(storageSize);
return this;
}
/**
*
* The valid range of provisioned IOPS. For example, 1000-20000.
*
*
* @return The valid range of provisioned IOPS. For example, 1000-20000.
*/
public java.util.List getProvisionedIops() {
if (provisionedIops == null) {
provisionedIops = new com.amazonaws.internal.SdkInternalList();
}
return provisionedIops;
}
/**
*
* The valid range of provisioned IOPS. For example, 1000-20000.
*
*
* @param provisionedIops
* The valid range of provisioned IOPS. For example, 1000-20000.
*/
public void setProvisionedIops(java.util.Collection provisionedIops) {
if (provisionedIops == null) {
this.provisionedIops = null;
return;
}
this.provisionedIops = new com.amazonaws.internal.SdkInternalList(provisionedIops);
}
/**
*
* The valid range of provisioned IOPS. For example, 1000-20000.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setProvisionedIops(java.util.Collection)} or {@link #withProvisionedIops(java.util.Collection)} if you
* want to override the existing values.
*
*
* @param provisionedIops
* The valid range of provisioned IOPS. For example, 1000-20000.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ValidStorageOptions withProvisionedIops(Range... provisionedIops) {
if (this.provisionedIops == null) {
setProvisionedIops(new com.amazonaws.internal.SdkInternalList(provisionedIops.length));
}
for (Range ele : provisionedIops) {
this.provisionedIops.add(ele);
}
return this;
}
/**
*
* The valid range of provisioned IOPS. For example, 1000-20000.
*
*
* @param provisionedIops
* The valid range of provisioned IOPS. For example, 1000-20000.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ValidStorageOptions withProvisionedIops(java.util.Collection provisionedIops) {
setProvisionedIops(provisionedIops);
return this;
}
/**
*
* The valid range of Provisioned IOPS to gibibytes of storage multiplier. For example, 3-10, which means that
* provisioned IOPS can be between 3 and 10 times storage.
*
*
* @return The valid range of Provisioned IOPS to gibibytes of storage multiplier. For example, 3-10, which means
* that provisioned IOPS can be between 3 and 10 times storage.
*/
public java.util.List getIopsToStorageRatio() {
if (iopsToStorageRatio == null) {
iopsToStorageRatio = new com.amazonaws.internal.SdkInternalList();
}
return iopsToStorageRatio;
}
/**
*
* The valid range of Provisioned IOPS to gibibytes of storage multiplier. For example, 3-10, which means that
* provisioned IOPS can be between 3 and 10 times storage.
*
*
* @param iopsToStorageRatio
* The valid range of Provisioned IOPS to gibibytes of storage multiplier. For example, 3-10, which means
* that provisioned IOPS can be between 3 and 10 times storage.
*/
public void setIopsToStorageRatio(java.util.Collection iopsToStorageRatio) {
if (iopsToStorageRatio == null) {
this.iopsToStorageRatio = null;
return;
}
this.iopsToStorageRatio = new com.amazonaws.internal.SdkInternalList(iopsToStorageRatio);
}
/**
*
* The valid range of Provisioned IOPS to gibibytes of storage multiplier. For example, 3-10, which means that
* provisioned IOPS can be between 3 and 10 times storage.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setIopsToStorageRatio(java.util.Collection)} or {@link #withIopsToStorageRatio(java.util.Collection)} if
* you want to override the existing values.
*
*
* @param iopsToStorageRatio
* The valid range of Provisioned IOPS to gibibytes of storage multiplier. For example, 3-10, which means
* that provisioned IOPS can be between 3 and 10 times storage.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ValidStorageOptions withIopsToStorageRatio(DoubleRange... iopsToStorageRatio) {
if (this.iopsToStorageRatio == null) {
setIopsToStorageRatio(new com.amazonaws.internal.SdkInternalList(iopsToStorageRatio.length));
}
for (DoubleRange ele : iopsToStorageRatio) {
this.iopsToStorageRatio.add(ele);
}
return this;
}
/**
*
* The valid range of Provisioned IOPS to gibibytes of storage multiplier. For example, 3-10, which means that
* provisioned IOPS can be between 3 and 10 times storage.
*
*
* @param iopsToStorageRatio
* The valid range of Provisioned IOPS to gibibytes of storage multiplier. For example, 3-10, which means
* that provisioned IOPS can be between 3 and 10 times storage.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ValidStorageOptions withIopsToStorageRatio(java.util.Collection iopsToStorageRatio) {
setIopsToStorageRatio(iopsToStorageRatio);
return this;
}
/**
*
* Whether or not Amazon RDS can automatically scale storage for DB instances that use the new instance class.
*
*
* @param supportsStorageAutoscaling
* Whether or not Amazon RDS can automatically scale storage for DB instances that use the new instance
* class.
*/
public void setSupportsStorageAutoscaling(Boolean supportsStorageAutoscaling) {
this.supportsStorageAutoscaling = supportsStorageAutoscaling;
}
/**
*
* Whether or not Amazon RDS can automatically scale storage for DB instances that use the new instance class.
*
*
* @return Whether or not Amazon RDS can automatically scale storage for DB instances that use the new instance
* class.
*/
public Boolean getSupportsStorageAutoscaling() {
return this.supportsStorageAutoscaling;
}
/**
*
* Whether or not Amazon RDS can automatically scale storage for DB instances that use the new instance class.
*
*
* @param supportsStorageAutoscaling
* Whether or not Amazon RDS can automatically scale storage for DB instances that use the new instance
* class.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ValidStorageOptions withSupportsStorageAutoscaling(Boolean supportsStorageAutoscaling) {
setSupportsStorageAutoscaling(supportsStorageAutoscaling);
return this;
}
/**
*
* Whether or not Amazon RDS can automatically scale storage for DB instances that use the new instance class.
*
*
* @return Whether or not Amazon RDS can automatically scale storage for DB instances that use the new instance
* class.
*/
public Boolean isSupportsStorageAutoscaling() {
return this.supportsStorageAutoscaling;
}
/**
* 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 (getStorageType() != null)
sb.append("StorageType: ").append(getStorageType()).append(",");
if (getStorageSize() != null)
sb.append("StorageSize: ").append(getStorageSize()).append(",");
if (getProvisionedIops() != null)
sb.append("ProvisionedIops: ").append(getProvisionedIops()).append(",");
if (getIopsToStorageRatio() != null)
sb.append("IopsToStorageRatio: ").append(getIopsToStorageRatio()).append(",");
if (getSupportsStorageAutoscaling() != null)
sb.append("SupportsStorageAutoscaling: ").append(getSupportsStorageAutoscaling());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof ValidStorageOptions == false)
return false;
ValidStorageOptions other = (ValidStorageOptions) obj;
if (other.getStorageType() == null ^ this.getStorageType() == null)
return false;
if (other.getStorageType() != null && other.getStorageType().equals(this.getStorageType()) == false)
return false;
if (other.getStorageSize() == null ^ this.getStorageSize() == null)
return false;
if (other.getStorageSize() != null && other.getStorageSize().equals(this.getStorageSize()) == false)
return false;
if (other.getProvisionedIops() == null ^ this.getProvisionedIops() == null)
return false;
if (other.getProvisionedIops() != null && other.getProvisionedIops().equals(this.getProvisionedIops()) == false)
return false;
if (other.getIopsToStorageRatio() == null ^ this.getIopsToStorageRatio() == null)
return false;
if (other.getIopsToStorageRatio() != null && other.getIopsToStorageRatio().equals(this.getIopsToStorageRatio()) == false)
return false;
if (other.getSupportsStorageAutoscaling() == null ^ this.getSupportsStorageAutoscaling() == null)
return false;
if (other.getSupportsStorageAutoscaling() != null && other.getSupportsStorageAutoscaling().equals(this.getSupportsStorageAutoscaling()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getStorageType() == null) ? 0 : getStorageType().hashCode());
hashCode = prime * hashCode + ((getStorageSize() == null) ? 0 : getStorageSize().hashCode());
hashCode = prime * hashCode + ((getProvisionedIops() == null) ? 0 : getProvisionedIops().hashCode());
hashCode = prime * hashCode + ((getIopsToStorageRatio() == null) ? 0 : getIopsToStorageRatio().hashCode());
hashCode = prime * hashCode + ((getSupportsStorageAutoscaling() == null) ? 0 : getSupportsStorageAutoscaling().hashCode());
return hashCode;
}
@Override
public ValidStorageOptions clone() {
try {
return (ValidStorageOptions) super.clone();
} catch (CloneNotSupportedException e) {
throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e);
}
}
}