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

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); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy