com.amazonaws.services.rds.model.ValidDBInstanceModificationsMessage Maven / Gradle / Ivy
Show all versions of aws-java-sdk-rds Show documentation
/*
* Copyright 2015-2020 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. You can use this information when you call
* ModifyDBInstance
.
*
*
* @see AWS API Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class ValidDBInstanceModificationsMessage implements Serializable, Cloneable {
/**
*
* Valid storage options for your DB instance.
*
*/
private com.amazonaws.internal.SdkInternalList storage;
/**
*
* Valid processor features for your DB instance.
*
*/
private com.amazonaws.internal.SdkInternalList validProcessorFeatures;
/**
*
* Valid storage options for your DB instance.
*
*
* @return Valid storage options for your DB instance.
*/
public java.util.List getStorage() {
if (storage == null) {
storage = new com.amazonaws.internal.SdkInternalList();
}
return storage;
}
/**
*
* Valid storage options for your DB instance.
*
*
* @param storage
* Valid storage options for your DB instance.
*/
public void setStorage(java.util.Collection storage) {
if (storage == null) {
this.storage = null;
return;
}
this.storage = new com.amazonaws.internal.SdkInternalList(storage);
}
/**
*
* Valid storage options for your DB instance.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setStorage(java.util.Collection)} or {@link #withStorage(java.util.Collection)} if you want to override
* the existing values.
*
*
* @param storage
* Valid storage options for your DB instance.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ValidDBInstanceModificationsMessage withStorage(ValidStorageOptions... storage) {
if (this.storage == null) {
setStorage(new com.amazonaws.internal.SdkInternalList(storage.length));
}
for (ValidStorageOptions ele : storage) {
this.storage.add(ele);
}
return this;
}
/**
*
* Valid storage options for your DB instance.
*
*
* @param storage
* Valid storage options for your DB instance.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ValidDBInstanceModificationsMessage withStorage(java.util.Collection storage) {
setStorage(storage);
return this;
}
/**
*
* Valid processor features for your DB instance.
*
*
* @return Valid processor features for your DB instance.
*/
public java.util.List getValidProcessorFeatures() {
if (validProcessorFeatures == null) {
validProcessorFeatures = new com.amazonaws.internal.SdkInternalList();
}
return validProcessorFeatures;
}
/**
*
* Valid processor features for your DB instance.
*
*
* @param validProcessorFeatures
* Valid processor features for your DB instance.
*/
public void setValidProcessorFeatures(java.util.Collection validProcessorFeatures) {
if (validProcessorFeatures == null) {
this.validProcessorFeatures = null;
return;
}
this.validProcessorFeatures = new com.amazonaws.internal.SdkInternalList(validProcessorFeatures);
}
/**
*
* Valid processor features for your DB instance.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setValidProcessorFeatures(java.util.Collection)} or
* {@link #withValidProcessorFeatures(java.util.Collection)} if you want to override the existing values.
*
*
* @param validProcessorFeatures
* Valid processor features for your DB instance.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ValidDBInstanceModificationsMessage withValidProcessorFeatures(AvailableProcessorFeature... validProcessorFeatures) {
if (this.validProcessorFeatures == null) {
setValidProcessorFeatures(new com.amazonaws.internal.SdkInternalList(validProcessorFeatures.length));
}
for (AvailableProcessorFeature ele : validProcessorFeatures) {
this.validProcessorFeatures.add(ele);
}
return this;
}
/**
*
* Valid processor features for your DB instance.
*
*
* @param validProcessorFeatures
* Valid processor features for your DB instance.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ValidDBInstanceModificationsMessage withValidProcessorFeatures(java.util.Collection validProcessorFeatures) {
setValidProcessorFeatures(validProcessorFeatures);
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 (getStorage() != null)
sb.append("Storage: ").append(getStorage()).append(",");
if (getValidProcessorFeatures() != null)
sb.append("ValidProcessorFeatures: ").append(getValidProcessorFeatures());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof ValidDBInstanceModificationsMessage == false)
return false;
ValidDBInstanceModificationsMessage other = (ValidDBInstanceModificationsMessage) obj;
if (other.getStorage() == null ^ this.getStorage() == null)
return false;
if (other.getStorage() != null && other.getStorage().equals(this.getStorage()) == false)
return false;
if (other.getValidProcessorFeatures() == null ^ this.getValidProcessorFeatures() == null)
return false;
if (other.getValidProcessorFeatures() != null && other.getValidProcessorFeatures().equals(this.getValidProcessorFeatures()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getStorage() == null) ? 0 : getStorage().hashCode());
hashCode = prime * hashCode + ((getValidProcessorFeatures() == null) ? 0 : getValidProcessorFeatures().hashCode());
return hashCode;
}
@Override
public ValidDBInstanceModificationsMessage clone() {
try {
return (ValidDBInstanceModificationsMessage) super.clone();
} catch (CloneNotSupportedException e) {
throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e);
}
}
}