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

com.amazonaws.services.elasticache.model.ModifyReplicationGroupShardConfigurationRequest Maven / Gradle / Ivy

/*
 * Copyright 2019-2024 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.elasticache.model;

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

import com.amazonaws.AmazonWebServiceRequest;

/**
 * 

* Represents the input for a ModifyReplicationGroupShardConfiguration operation. *

* * @see AWS API Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class ModifyReplicationGroupShardConfigurationRequest extends com.amazonaws.AmazonWebServiceRequest implements Serializable, Cloneable { /** *

* The name of the Redis OSS (cluster mode enabled) cluster (replication group) on which the shards are to be * configured. *

*/ private String replicationGroupId; /** *

* The number of node groups (shards) that results from the modification of the shard configuration. *

*/ private Integer nodeGroupCount; /** *

* Indicates that the shard reconfiguration process begins immediately. At present, the only permitted value for * this parameter is true. *

*

* Value: true *

*/ private Boolean applyImmediately; /** *

* Specifies the preferred availability zones for each node group in the cluster. If the value of * NodeGroupCount is greater than the current number of node groups (shards), you can use this * parameter to specify the preferred availability zones of the cluster's shards. If you omit this parameter * ElastiCache selects availability zones for you. *

*

* You can specify this parameter only if the value of NodeGroupCount is greater than the current * number of node groups (shards). *

*/ private com.amazonaws.internal.SdkInternalList reshardingConfiguration; /** *

* If the value of NodeGroupCount is less than the current number of node groups (shards), then either * NodeGroupsToRemove or NodeGroupsToRetain is required. NodeGroupsToRemove * is a list of NodeGroupIds to remove from the cluster. *

*

* ElastiCache (Redis OSS) will attempt to remove all node groups listed by NodeGroupsToRemove from the * cluster. *

*/ private com.amazonaws.internal.SdkInternalList nodeGroupsToRemove; /** *

* If the value of NodeGroupCount is less than the current number of node groups (shards), then either * NodeGroupsToRemove or NodeGroupsToRetain is required. NodeGroupsToRetain * is a list of NodeGroupIds to retain in the cluster. *

*

* ElastiCache (Redis OSS) will attempt to remove all node groups except those listed by * NodeGroupsToRetain from the cluster. *

*/ private com.amazonaws.internal.SdkInternalList nodeGroupsToRetain; /** *

* The name of the Redis OSS (cluster mode enabled) cluster (replication group) on which the shards are to be * configured. *

* * @param replicationGroupId * The name of the Redis OSS (cluster mode enabled) cluster (replication group) on which the shards are to be * configured. */ public void setReplicationGroupId(String replicationGroupId) { this.replicationGroupId = replicationGroupId; } /** *

* The name of the Redis OSS (cluster mode enabled) cluster (replication group) on which the shards are to be * configured. *

* * @return The name of the Redis OSS (cluster mode enabled) cluster (replication group) on which the shards are to * be configured. */ public String getReplicationGroupId() { return this.replicationGroupId; } /** *

* The name of the Redis OSS (cluster mode enabled) cluster (replication group) on which the shards are to be * configured. *

* * @param replicationGroupId * The name of the Redis OSS (cluster mode enabled) cluster (replication group) on which the shards are to be * configured. * @return Returns a reference to this object so that method calls can be chained together. */ public ModifyReplicationGroupShardConfigurationRequest withReplicationGroupId(String replicationGroupId) { setReplicationGroupId(replicationGroupId); return this; } /** *

* The number of node groups (shards) that results from the modification of the shard configuration. *

* * @param nodeGroupCount * The number of node groups (shards) that results from the modification of the shard configuration. */ public void setNodeGroupCount(Integer nodeGroupCount) { this.nodeGroupCount = nodeGroupCount; } /** *

* The number of node groups (shards) that results from the modification of the shard configuration. *

* * @return The number of node groups (shards) that results from the modification of the shard configuration. */ public Integer getNodeGroupCount() { return this.nodeGroupCount; } /** *

* The number of node groups (shards) that results from the modification of the shard configuration. *

* * @param nodeGroupCount * The number of node groups (shards) that results from the modification of the shard configuration. * @return Returns a reference to this object so that method calls can be chained together. */ public ModifyReplicationGroupShardConfigurationRequest withNodeGroupCount(Integer nodeGroupCount) { setNodeGroupCount(nodeGroupCount); return this; } /** *

* Indicates that the shard reconfiguration process begins immediately. At present, the only permitted value for * this parameter is true. *

*

* Value: true *

* * @param applyImmediately * Indicates that the shard reconfiguration process begins immediately. At present, the only permitted value * for this parameter is true.

*

* Value: true */ public void setApplyImmediately(Boolean applyImmediately) { this.applyImmediately = applyImmediately; } /** *

* Indicates that the shard reconfiguration process begins immediately. At present, the only permitted value for * this parameter is true. *

*

* Value: true *

* * @return Indicates that the shard reconfiguration process begins immediately. At present, the only permitted value * for this parameter is true.

*

* Value: true */ public Boolean getApplyImmediately() { return this.applyImmediately; } /** *

* Indicates that the shard reconfiguration process begins immediately. At present, the only permitted value for * this parameter is true. *

*

* Value: true *

* * @param applyImmediately * Indicates that the shard reconfiguration process begins immediately. At present, the only permitted value * for this parameter is true.

*

* Value: true * @return Returns a reference to this object so that method calls can be chained together. */ public ModifyReplicationGroupShardConfigurationRequest withApplyImmediately(Boolean applyImmediately) { setApplyImmediately(applyImmediately); return this; } /** *

* Indicates that the shard reconfiguration process begins immediately. At present, the only permitted value for * this parameter is true. *

*

* Value: true *

* * @return Indicates that the shard reconfiguration process begins immediately. At present, the only permitted value * for this parameter is true.

*

* Value: true */ public Boolean isApplyImmediately() { return this.applyImmediately; } /** *

* Specifies the preferred availability zones for each node group in the cluster. If the value of * NodeGroupCount is greater than the current number of node groups (shards), you can use this * parameter to specify the preferred availability zones of the cluster's shards. If you omit this parameter * ElastiCache selects availability zones for you. *

*

* You can specify this parameter only if the value of NodeGroupCount is greater than the current * number of node groups (shards). *

* * @return Specifies the preferred availability zones for each node group in the cluster. If the value of * NodeGroupCount is greater than the current number of node groups (shards), you can use this * parameter to specify the preferred availability zones of the cluster's shards. If you omit this parameter * ElastiCache selects availability zones for you.

*

* You can specify this parameter only if the value of NodeGroupCount is greater than the * current number of node groups (shards). */ public java.util.List getReshardingConfiguration() { if (reshardingConfiguration == null) { reshardingConfiguration = new com.amazonaws.internal.SdkInternalList(); } return reshardingConfiguration; } /** *

* Specifies the preferred availability zones for each node group in the cluster. If the value of * NodeGroupCount is greater than the current number of node groups (shards), you can use this * parameter to specify the preferred availability zones of the cluster's shards. If you omit this parameter * ElastiCache selects availability zones for you. *

*

* You can specify this parameter only if the value of NodeGroupCount is greater than the current * number of node groups (shards). *

* * @param reshardingConfiguration * Specifies the preferred availability zones for each node group in the cluster. If the value of * NodeGroupCount is greater than the current number of node groups (shards), you can use this * parameter to specify the preferred availability zones of the cluster's shards. If you omit this parameter * ElastiCache selects availability zones for you.

*

* You can specify this parameter only if the value of NodeGroupCount is greater than the * current number of node groups (shards). */ public void setReshardingConfiguration(java.util.Collection reshardingConfiguration) { if (reshardingConfiguration == null) { this.reshardingConfiguration = null; return; } this.reshardingConfiguration = new com.amazonaws.internal.SdkInternalList(reshardingConfiguration); } /** *

* Specifies the preferred availability zones for each node group in the cluster. If the value of * NodeGroupCount is greater than the current number of node groups (shards), you can use this * parameter to specify the preferred availability zones of the cluster's shards. If you omit this parameter * ElastiCache selects availability zones for you. *

*

* You can specify this parameter only if the value of NodeGroupCount is greater than the current * number of node groups (shards). *

*

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

* * @param reshardingConfiguration * Specifies the preferred availability zones for each node group in the cluster. If the value of * NodeGroupCount is greater than the current number of node groups (shards), you can use this * parameter to specify the preferred availability zones of the cluster's shards. If you omit this parameter * ElastiCache selects availability zones for you.

*

* You can specify this parameter only if the value of NodeGroupCount is greater than the * current number of node groups (shards). * @return Returns a reference to this object so that method calls can be chained together. */ public ModifyReplicationGroupShardConfigurationRequest withReshardingConfiguration(ReshardingConfiguration... reshardingConfiguration) { if (this.reshardingConfiguration == null) { setReshardingConfiguration(new com.amazonaws.internal.SdkInternalList(reshardingConfiguration.length)); } for (ReshardingConfiguration ele : reshardingConfiguration) { this.reshardingConfiguration.add(ele); } return this; } /** *

* Specifies the preferred availability zones for each node group in the cluster. If the value of * NodeGroupCount is greater than the current number of node groups (shards), you can use this * parameter to specify the preferred availability zones of the cluster's shards. If you omit this parameter * ElastiCache selects availability zones for you. *

*

* You can specify this parameter only if the value of NodeGroupCount is greater than the current * number of node groups (shards). *

* * @param reshardingConfiguration * Specifies the preferred availability zones for each node group in the cluster. If the value of * NodeGroupCount is greater than the current number of node groups (shards), you can use this * parameter to specify the preferred availability zones of the cluster's shards. If you omit this parameter * ElastiCache selects availability zones for you.

*

* You can specify this parameter only if the value of NodeGroupCount is greater than the * current number of node groups (shards). * @return Returns a reference to this object so that method calls can be chained together. */ public ModifyReplicationGroupShardConfigurationRequest withReshardingConfiguration(java.util.Collection reshardingConfiguration) { setReshardingConfiguration(reshardingConfiguration); return this; } /** *

* If the value of NodeGroupCount is less than the current number of node groups (shards), then either * NodeGroupsToRemove or NodeGroupsToRetain is required. NodeGroupsToRemove * is a list of NodeGroupIds to remove from the cluster. *

*

* ElastiCache (Redis OSS) will attempt to remove all node groups listed by NodeGroupsToRemove from the * cluster. *

* * @return If the value of NodeGroupCount is less than the current number of node groups (shards), then * either NodeGroupsToRemove or NodeGroupsToRetain is required. * NodeGroupsToRemove is a list of NodeGroupIds to remove from the cluster.

*

* ElastiCache (Redis OSS) will attempt to remove all node groups listed by NodeGroupsToRemove * from the cluster. */ public java.util.List getNodeGroupsToRemove() { if (nodeGroupsToRemove == null) { nodeGroupsToRemove = new com.amazonaws.internal.SdkInternalList(); } return nodeGroupsToRemove; } /** *

* If the value of NodeGroupCount is less than the current number of node groups (shards), then either * NodeGroupsToRemove or NodeGroupsToRetain is required. NodeGroupsToRemove * is a list of NodeGroupIds to remove from the cluster. *

*

* ElastiCache (Redis OSS) will attempt to remove all node groups listed by NodeGroupsToRemove from the * cluster. *

* * @param nodeGroupsToRemove * If the value of NodeGroupCount is less than the current number of node groups (shards), then * either NodeGroupsToRemove or NodeGroupsToRetain is required. * NodeGroupsToRemove is a list of NodeGroupIds to remove from the cluster.

*

* ElastiCache (Redis OSS) will attempt to remove all node groups listed by NodeGroupsToRemove * from the cluster. */ public void setNodeGroupsToRemove(java.util.Collection nodeGroupsToRemove) { if (nodeGroupsToRemove == null) { this.nodeGroupsToRemove = null; return; } this.nodeGroupsToRemove = new com.amazonaws.internal.SdkInternalList(nodeGroupsToRemove); } /** *

* If the value of NodeGroupCount is less than the current number of node groups (shards), then either * NodeGroupsToRemove or NodeGroupsToRetain is required. NodeGroupsToRemove * is a list of NodeGroupIds to remove from the cluster. *

*

* ElastiCache (Redis OSS) will attempt to remove all node groups listed by NodeGroupsToRemove from the * cluster. *

*

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

* * @param nodeGroupsToRemove * If the value of NodeGroupCount is less than the current number of node groups (shards), then * either NodeGroupsToRemove or NodeGroupsToRetain is required. * NodeGroupsToRemove is a list of NodeGroupIds to remove from the cluster.

*

* ElastiCache (Redis OSS) will attempt to remove all node groups listed by NodeGroupsToRemove * from the cluster. * @return Returns a reference to this object so that method calls can be chained together. */ public ModifyReplicationGroupShardConfigurationRequest withNodeGroupsToRemove(String... nodeGroupsToRemove) { if (this.nodeGroupsToRemove == null) { setNodeGroupsToRemove(new com.amazonaws.internal.SdkInternalList(nodeGroupsToRemove.length)); } for (String ele : nodeGroupsToRemove) { this.nodeGroupsToRemove.add(ele); } return this; } /** *

* If the value of NodeGroupCount is less than the current number of node groups (shards), then either * NodeGroupsToRemove or NodeGroupsToRetain is required. NodeGroupsToRemove * is a list of NodeGroupIds to remove from the cluster. *

*

* ElastiCache (Redis OSS) will attempt to remove all node groups listed by NodeGroupsToRemove from the * cluster. *

* * @param nodeGroupsToRemove * If the value of NodeGroupCount is less than the current number of node groups (shards), then * either NodeGroupsToRemove or NodeGroupsToRetain is required. * NodeGroupsToRemove is a list of NodeGroupIds to remove from the cluster.

*

* ElastiCache (Redis OSS) will attempt to remove all node groups listed by NodeGroupsToRemove * from the cluster. * @return Returns a reference to this object so that method calls can be chained together. */ public ModifyReplicationGroupShardConfigurationRequest withNodeGroupsToRemove(java.util.Collection nodeGroupsToRemove) { setNodeGroupsToRemove(nodeGroupsToRemove); return this; } /** *

* If the value of NodeGroupCount is less than the current number of node groups (shards), then either * NodeGroupsToRemove or NodeGroupsToRetain is required. NodeGroupsToRetain * is a list of NodeGroupIds to retain in the cluster. *

*

* ElastiCache (Redis OSS) will attempt to remove all node groups except those listed by * NodeGroupsToRetain from the cluster. *

* * @return If the value of NodeGroupCount is less than the current number of node groups (shards), then * either NodeGroupsToRemove or NodeGroupsToRetain is required. * NodeGroupsToRetain is a list of NodeGroupIds to retain in the cluster.

*

* ElastiCache (Redis OSS) will attempt to remove all node groups except those listed by * NodeGroupsToRetain from the cluster. */ public java.util.List getNodeGroupsToRetain() { if (nodeGroupsToRetain == null) { nodeGroupsToRetain = new com.amazonaws.internal.SdkInternalList(); } return nodeGroupsToRetain; } /** *

* If the value of NodeGroupCount is less than the current number of node groups (shards), then either * NodeGroupsToRemove or NodeGroupsToRetain is required. NodeGroupsToRetain * is a list of NodeGroupIds to retain in the cluster. *

*

* ElastiCache (Redis OSS) will attempt to remove all node groups except those listed by * NodeGroupsToRetain from the cluster. *

* * @param nodeGroupsToRetain * If the value of NodeGroupCount is less than the current number of node groups (shards), then * either NodeGroupsToRemove or NodeGroupsToRetain is required. * NodeGroupsToRetain is a list of NodeGroupIds to retain in the cluster.

*

* ElastiCache (Redis OSS) will attempt to remove all node groups except those listed by * NodeGroupsToRetain from the cluster. */ public void setNodeGroupsToRetain(java.util.Collection nodeGroupsToRetain) { if (nodeGroupsToRetain == null) { this.nodeGroupsToRetain = null; return; } this.nodeGroupsToRetain = new com.amazonaws.internal.SdkInternalList(nodeGroupsToRetain); } /** *

* If the value of NodeGroupCount is less than the current number of node groups (shards), then either * NodeGroupsToRemove or NodeGroupsToRetain is required. NodeGroupsToRetain * is a list of NodeGroupIds to retain in the cluster. *

*

* ElastiCache (Redis OSS) will attempt to remove all node groups except those listed by * NodeGroupsToRetain from the cluster. *

*

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

* * @param nodeGroupsToRetain * If the value of NodeGroupCount is less than the current number of node groups (shards), then * either NodeGroupsToRemove or NodeGroupsToRetain is required. * NodeGroupsToRetain is a list of NodeGroupIds to retain in the cluster.

*

* ElastiCache (Redis OSS) will attempt to remove all node groups except those listed by * NodeGroupsToRetain from the cluster. * @return Returns a reference to this object so that method calls can be chained together. */ public ModifyReplicationGroupShardConfigurationRequest withNodeGroupsToRetain(String... nodeGroupsToRetain) { if (this.nodeGroupsToRetain == null) { setNodeGroupsToRetain(new com.amazonaws.internal.SdkInternalList(nodeGroupsToRetain.length)); } for (String ele : nodeGroupsToRetain) { this.nodeGroupsToRetain.add(ele); } return this; } /** *

* If the value of NodeGroupCount is less than the current number of node groups (shards), then either * NodeGroupsToRemove or NodeGroupsToRetain is required. NodeGroupsToRetain * is a list of NodeGroupIds to retain in the cluster. *

*

* ElastiCache (Redis OSS) will attempt to remove all node groups except those listed by * NodeGroupsToRetain from the cluster. *

* * @param nodeGroupsToRetain * If the value of NodeGroupCount is less than the current number of node groups (shards), then * either NodeGroupsToRemove or NodeGroupsToRetain is required. * NodeGroupsToRetain is a list of NodeGroupIds to retain in the cluster.

*

* ElastiCache (Redis OSS) will attempt to remove all node groups except those listed by * NodeGroupsToRetain from the cluster. * @return Returns a reference to this object so that method calls can be chained together. */ public ModifyReplicationGroupShardConfigurationRequest withNodeGroupsToRetain(java.util.Collection nodeGroupsToRetain) { setNodeGroupsToRetain(nodeGroupsToRetain); 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 (getReplicationGroupId() != null) sb.append("ReplicationGroupId: ").append(getReplicationGroupId()).append(","); if (getNodeGroupCount() != null) sb.append("NodeGroupCount: ").append(getNodeGroupCount()).append(","); if (getApplyImmediately() != null) sb.append("ApplyImmediately: ").append(getApplyImmediately()).append(","); if (getReshardingConfiguration() != null) sb.append("ReshardingConfiguration: ").append(getReshardingConfiguration()).append(","); if (getNodeGroupsToRemove() != null) sb.append("NodeGroupsToRemove: ").append(getNodeGroupsToRemove()).append(","); if (getNodeGroupsToRetain() != null) sb.append("NodeGroupsToRetain: ").append(getNodeGroupsToRetain()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof ModifyReplicationGroupShardConfigurationRequest == false) return false; ModifyReplicationGroupShardConfigurationRequest other = (ModifyReplicationGroupShardConfigurationRequest) obj; if (other.getReplicationGroupId() == null ^ this.getReplicationGroupId() == null) return false; if (other.getReplicationGroupId() != null && other.getReplicationGroupId().equals(this.getReplicationGroupId()) == false) return false; if (other.getNodeGroupCount() == null ^ this.getNodeGroupCount() == null) return false; if (other.getNodeGroupCount() != null && other.getNodeGroupCount().equals(this.getNodeGroupCount()) == false) return false; if (other.getApplyImmediately() == null ^ this.getApplyImmediately() == null) return false; if (other.getApplyImmediately() != null && other.getApplyImmediately().equals(this.getApplyImmediately()) == false) return false; if (other.getReshardingConfiguration() == null ^ this.getReshardingConfiguration() == null) return false; if (other.getReshardingConfiguration() != null && other.getReshardingConfiguration().equals(this.getReshardingConfiguration()) == false) return false; if (other.getNodeGroupsToRemove() == null ^ this.getNodeGroupsToRemove() == null) return false; if (other.getNodeGroupsToRemove() != null && other.getNodeGroupsToRemove().equals(this.getNodeGroupsToRemove()) == false) return false; if (other.getNodeGroupsToRetain() == null ^ this.getNodeGroupsToRetain() == null) return false; if (other.getNodeGroupsToRetain() != null && other.getNodeGroupsToRetain().equals(this.getNodeGroupsToRetain()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getReplicationGroupId() == null) ? 0 : getReplicationGroupId().hashCode()); hashCode = prime * hashCode + ((getNodeGroupCount() == null) ? 0 : getNodeGroupCount().hashCode()); hashCode = prime * hashCode + ((getApplyImmediately() == null) ? 0 : getApplyImmediately().hashCode()); hashCode = prime * hashCode + ((getReshardingConfiguration() == null) ? 0 : getReshardingConfiguration().hashCode()); hashCode = prime * hashCode + ((getNodeGroupsToRemove() == null) ? 0 : getNodeGroupsToRemove().hashCode()); hashCode = prime * hashCode + ((getNodeGroupsToRetain() == null) ? 0 : getNodeGroupsToRetain().hashCode()); return hashCode; } @Override public ModifyReplicationGroupShardConfigurationRequest clone() { return (ModifyReplicationGroupShardConfigurationRequest) super.clone(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy