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

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

/*
 * Copyright 2010-2015 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 com.amazonaws.AmazonWebServiceRequest;

/**
 * Container for the parameters to the {@link com.amazonaws.services.elasticache.AmazonElastiCache#modifyReplicationGroup(ModifyReplicationGroupRequest) ModifyReplicationGroup operation}.
 * 

* The ModifyReplicationGroup operation modifies the settings for * a replication group. *

* * @see com.amazonaws.services.elasticache.AmazonElastiCache#modifyReplicationGroup(ModifyReplicationGroupRequest) */ public class ModifyReplicationGroupRequest extends AmazonWebServiceRequest implements Serializable { /** * The identifier of the replication group to modify. */ private String replicationGroupId; /** * A description for the replication group. Maximum length is 255 * characters. */ private String replicationGroupDescription; /** * If this parameter is specified, ElastiCache will promote each of the * cache clusters in the specified replication group to the primary role. * The nodes of all other cache clusters in the replication group will be * read replicas. */ private String primaryClusterId; /** * The cache cluster ID that will be used as the daily snapshot source * for the replication group. */ private String snapshottingClusterId; /** * Whether a read replica will be automatically promoted to read/write * primary if the existing primary encounters a failure.

Valid values: * true | false

ElastiCache Multi-AZ * replication groups is not supported on:

  • Redis version * 2.6.
  • T1 and T2 cache node types.
*/ private Boolean automaticFailoverEnabled; /** * A list of cache security group names to authorize for the clusters in * this replication group. This change is asynchronously applied as soon * as possible.

This parameter can be used only with replication group * containing cache clusters running outside of an Amazon Virtual Private * Cloud (VPC).

Constraints: Must contain no more than 255 * alphanumeric characters. Must not be "Default". */ private com.amazonaws.internal.ListWithAutoConstructFlag cacheSecurityGroupNames; /** * Specifies the VPC Security Groups associated with the cache clusters * in the replication group.

This parameter can be used only with * replication group containing cache clusters running in an Amazon * Virtual Private Cloud (VPC). */ private com.amazonaws.internal.ListWithAutoConstructFlag securityGroupIds; /** * The weekly time range (in UTC) during which replication group system * maintenance can occur. Note that system maintenance may result in an * outage. This change is made immediately. If you are moving this window * to the current time, there must be at least 120 minutes between the * current time and end of the window to ensure that pending changes are * applied. */ private String preferredMaintenanceWindow; /** * The Amazon Resource Name (ARN) of the Amazon SNS topic to which * notifications will be sent. The Amazon SNS topic owner must be * same as the replication group owner. */ private String notificationTopicArn; /** * The name of the cache parameter group to apply to all of the clusters * in this replication group. This change is asynchronously applied as * soon as possible for parameters when the ApplyImmediately * parameter is specified as true for this request. */ private String cacheParameterGroupName; /** * The status of the Amazon SNS notification topic for the replication * group. Notifications are sent only if the status is active. *

Valid values: active | inactive */ private String notificationTopicStatus; /** * If true, this parameter causes the modifications in this * request and any pending modifications to be applied, asynchronously * and as soon as possible, regardless of the * PreferredMaintenanceWindow setting for the replication group. *

If false, then changes to the nodes in the replication * group are applied on the next maintenance reboot, or the next failure * reboot, whichever occurs first.

Valid values: true | * false

Default: false */ private Boolean applyImmediately; /** * The upgraded version of the cache engine to be run on the cache * clusters in the replication group. */ private String engineVersion; /** * Determines whether minor engine upgrades will be applied automatically * to all of the clusters in the replication group during the maintenance * window. A value of true allows these upgrades to occur; * false disables automatic upgrades. */ private Boolean autoMinorVersionUpgrade; /** * The number of days for which ElastiCache will retain automatic node * group snapshots before deleting them. For example, if you set * SnapshotRetentionLimit to 5, then a snapshot that was taken * today will be retained for 5 days before being deleted. *

Important
If the value of SnapshotRetentionLimit is set * to zero (0), backups are turned off. */ private Integer snapshotRetentionLimit; /** * The daily time range (in UTC) during which ElastiCache will begin * taking a daily snapshot of the node group specified by * SnapshottingClusterId.

Example: 05:00-09:00 *

If you do not specify this parameter, then ElastiCache will * automatically choose an appropriate time range. */ private String snapshotWindow; /** * The identifier of the replication group to modify. * * @return The identifier of the replication group to modify. */ public String getReplicationGroupId() { return replicationGroupId; } /** * The identifier of the replication group to modify. * * @param replicationGroupId The identifier of the replication group to modify. */ public void setReplicationGroupId(String replicationGroupId) { this.replicationGroupId = replicationGroupId; } /** * The identifier of the replication group to modify. *

* Returns a reference to this object so that method calls can be chained together. * * @param replicationGroupId The identifier of the replication group to modify. * * @return A reference to this updated object so that method calls can be chained * together. */ public ModifyReplicationGroupRequest withReplicationGroupId(String replicationGroupId) { this.replicationGroupId = replicationGroupId; return this; } /** * A description for the replication group. Maximum length is 255 * characters. * * @return A description for the replication group. Maximum length is 255 * characters. */ public String getReplicationGroupDescription() { return replicationGroupDescription; } /** * A description for the replication group. Maximum length is 255 * characters. * * @param replicationGroupDescription A description for the replication group. Maximum length is 255 * characters. */ public void setReplicationGroupDescription(String replicationGroupDescription) { this.replicationGroupDescription = replicationGroupDescription; } /** * A description for the replication group. Maximum length is 255 * characters. *

* Returns a reference to this object so that method calls can be chained together. * * @param replicationGroupDescription A description for the replication group. Maximum length is 255 * characters. * * @return A reference to this updated object so that method calls can be chained * together. */ public ModifyReplicationGroupRequest withReplicationGroupDescription(String replicationGroupDescription) { this.replicationGroupDescription = replicationGroupDescription; return this; } /** * If this parameter is specified, ElastiCache will promote each of the * cache clusters in the specified replication group to the primary role. * The nodes of all other cache clusters in the replication group will be * read replicas. * * @return If this parameter is specified, ElastiCache will promote each of the * cache clusters in the specified replication group to the primary role. * The nodes of all other cache clusters in the replication group will be * read replicas. */ public String getPrimaryClusterId() { return primaryClusterId; } /** * If this parameter is specified, ElastiCache will promote each of the * cache clusters in the specified replication group to the primary role. * The nodes of all other cache clusters in the replication group will be * read replicas. * * @param primaryClusterId If this parameter is specified, ElastiCache will promote each of the * cache clusters in the specified replication group to the primary role. * The nodes of all other cache clusters in the replication group will be * read replicas. */ public void setPrimaryClusterId(String primaryClusterId) { this.primaryClusterId = primaryClusterId; } /** * If this parameter is specified, ElastiCache will promote each of the * cache clusters in the specified replication group to the primary role. * The nodes of all other cache clusters in the replication group will be * read replicas. *

* Returns a reference to this object so that method calls can be chained together. * * @param primaryClusterId If this parameter is specified, ElastiCache will promote each of the * cache clusters in the specified replication group to the primary role. * The nodes of all other cache clusters in the replication group will be * read replicas. * * @return A reference to this updated object so that method calls can be chained * together. */ public ModifyReplicationGroupRequest withPrimaryClusterId(String primaryClusterId) { this.primaryClusterId = primaryClusterId; return this; } /** * The cache cluster ID that will be used as the daily snapshot source * for the replication group. * * @return The cache cluster ID that will be used as the daily snapshot source * for the replication group. */ public String getSnapshottingClusterId() { return snapshottingClusterId; } /** * The cache cluster ID that will be used as the daily snapshot source * for the replication group. * * @param snapshottingClusterId The cache cluster ID that will be used as the daily snapshot source * for the replication group. */ public void setSnapshottingClusterId(String snapshottingClusterId) { this.snapshottingClusterId = snapshottingClusterId; } /** * The cache cluster ID that will be used as the daily snapshot source * for the replication group. *

* Returns a reference to this object so that method calls can be chained together. * * @param snapshottingClusterId The cache cluster ID that will be used as the daily snapshot source * for the replication group. * * @return A reference to this updated object so that method calls can be chained * together. */ public ModifyReplicationGroupRequest withSnapshottingClusterId(String snapshottingClusterId) { this.snapshottingClusterId = snapshottingClusterId; return this; } /** * Whether a read replica will be automatically promoted to read/write * primary if the existing primary encounters a failure.

Valid values: * true | false

ElastiCache Multi-AZ * replication groups is not supported on:

  • Redis version * 2.6.
  • T1 and T2 cache node types.
* * @return Whether a read replica will be automatically promoted to read/write * primary if the existing primary encounters a failure.

Valid values: * true | false

ElastiCache Multi-AZ * replication groups is not supported on:

  • Redis version * 2.6.
  • T1 and T2 cache node types.
*/ public Boolean isAutomaticFailoverEnabled() { return automaticFailoverEnabled; } /** * Whether a read replica will be automatically promoted to read/write * primary if the existing primary encounters a failure.

Valid values: * true | false

ElastiCache Multi-AZ * replication groups is not supported on:

  • Redis version * 2.6.
  • T1 and T2 cache node types.
* * @param automaticFailoverEnabled Whether a read replica will be automatically promoted to read/write * primary if the existing primary encounters a failure.

Valid values: * true | false

ElastiCache Multi-AZ * replication groups is not supported on:

  • Redis version * 2.6.
  • T1 and T2 cache node types.
*/ public void setAutomaticFailoverEnabled(Boolean automaticFailoverEnabled) { this.automaticFailoverEnabled = automaticFailoverEnabled; } /** * Whether a read replica will be automatically promoted to read/write * primary if the existing primary encounters a failure.

Valid values: * true | false

ElastiCache Multi-AZ * replication groups is not supported on:

  • Redis version * 2.6.
  • T1 and T2 cache node types.
*

* Returns a reference to this object so that method calls can be chained together. * * @param automaticFailoverEnabled Whether a read replica will be automatically promoted to read/write * primary if the existing primary encounters a failure.

Valid values: * true | false

ElastiCache Multi-AZ * replication groups is not supported on:

  • Redis version * 2.6.
  • T1 and T2 cache node types.
* * @return A reference to this updated object so that method calls can be chained * together. */ public ModifyReplicationGroupRequest withAutomaticFailoverEnabled(Boolean automaticFailoverEnabled) { this.automaticFailoverEnabled = automaticFailoverEnabled; return this; } /** * Whether a read replica will be automatically promoted to read/write * primary if the existing primary encounters a failure.

Valid values: * true | false

ElastiCache Multi-AZ * replication groups is not supported on:

  • Redis version * 2.6.
  • T1 and T2 cache node types.
* * @return Whether a read replica will be automatically promoted to read/write * primary if the existing primary encounters a failure.

Valid values: * true | false

ElastiCache Multi-AZ * replication groups is not supported on:

  • Redis version * 2.6.
  • T1 and T2 cache node types.
*/ public Boolean getAutomaticFailoverEnabled() { return automaticFailoverEnabled; } /** * A list of cache security group names to authorize for the clusters in * this replication group. This change is asynchronously applied as soon * as possible.

This parameter can be used only with replication group * containing cache clusters running outside of an Amazon Virtual Private * Cloud (VPC).

Constraints: Must contain no more than 255 * alphanumeric characters. Must not be "Default". * * @return A list of cache security group names to authorize for the clusters in * this replication group. This change is asynchronously applied as soon * as possible.

This parameter can be used only with replication group * containing cache clusters running outside of an Amazon Virtual Private * Cloud (VPC).

Constraints: Must contain no more than 255 * alphanumeric characters. Must not be "Default". */ public java.util.List getCacheSecurityGroupNames() { if (cacheSecurityGroupNames == null) { cacheSecurityGroupNames = new com.amazonaws.internal.ListWithAutoConstructFlag(); cacheSecurityGroupNames.setAutoConstruct(true); } return cacheSecurityGroupNames; } /** * A list of cache security group names to authorize for the clusters in * this replication group. This change is asynchronously applied as soon * as possible.

This parameter can be used only with replication group * containing cache clusters running outside of an Amazon Virtual Private * Cloud (VPC).

Constraints: Must contain no more than 255 * alphanumeric characters. Must not be "Default". * * @param cacheSecurityGroupNames A list of cache security group names to authorize for the clusters in * this replication group. This change is asynchronously applied as soon * as possible.

This parameter can be used only with replication group * containing cache clusters running outside of an Amazon Virtual Private * Cloud (VPC).

Constraints: Must contain no more than 255 * alphanumeric characters. Must not be "Default". */ public void setCacheSecurityGroupNames(java.util.Collection cacheSecurityGroupNames) { if (cacheSecurityGroupNames == null) { this.cacheSecurityGroupNames = null; return; } com.amazonaws.internal.ListWithAutoConstructFlag cacheSecurityGroupNamesCopy = new com.amazonaws.internal.ListWithAutoConstructFlag(cacheSecurityGroupNames.size()); cacheSecurityGroupNamesCopy.addAll(cacheSecurityGroupNames); this.cacheSecurityGroupNames = cacheSecurityGroupNamesCopy; } /** * A list of cache security group names to authorize for the clusters in * this replication group. This change is asynchronously applied as soon * as possible.

This parameter can be used only with replication group * containing cache clusters running outside of an Amazon Virtual Private * Cloud (VPC).

Constraints: Must contain no more than 255 * alphanumeric characters. Must not be "Default". *

* Returns a reference to this object so that method calls can be chained together. * * @param cacheSecurityGroupNames A list of cache security group names to authorize for the clusters in * this replication group. This change is asynchronously applied as soon * as possible.

This parameter can be used only with replication group * containing cache clusters running outside of an Amazon Virtual Private * Cloud (VPC).

Constraints: Must contain no more than 255 * alphanumeric characters. Must not be "Default". * * @return A reference to this updated object so that method calls can be chained * together. */ public ModifyReplicationGroupRequest withCacheSecurityGroupNames(String... cacheSecurityGroupNames) { if (getCacheSecurityGroupNames() == null) setCacheSecurityGroupNames(new java.util.ArrayList(cacheSecurityGroupNames.length)); for (String value : cacheSecurityGroupNames) { getCacheSecurityGroupNames().add(value); } return this; } /** * A list of cache security group names to authorize for the clusters in * this replication group. This change is asynchronously applied as soon * as possible.

This parameter can be used only with replication group * containing cache clusters running outside of an Amazon Virtual Private * Cloud (VPC).

Constraints: Must contain no more than 255 * alphanumeric characters. Must not be "Default". *

* Returns a reference to this object so that method calls can be chained together. * * @param cacheSecurityGroupNames A list of cache security group names to authorize for the clusters in * this replication group. This change is asynchronously applied as soon * as possible.

This parameter can be used only with replication group * containing cache clusters running outside of an Amazon Virtual Private * Cloud (VPC).

Constraints: Must contain no more than 255 * alphanumeric characters. Must not be "Default". * * @return A reference to this updated object so that method calls can be chained * together. */ public ModifyReplicationGroupRequest withCacheSecurityGroupNames(java.util.Collection cacheSecurityGroupNames) { if (cacheSecurityGroupNames == null) { this.cacheSecurityGroupNames = null; } else { com.amazonaws.internal.ListWithAutoConstructFlag cacheSecurityGroupNamesCopy = new com.amazonaws.internal.ListWithAutoConstructFlag(cacheSecurityGroupNames.size()); cacheSecurityGroupNamesCopy.addAll(cacheSecurityGroupNames); this.cacheSecurityGroupNames = cacheSecurityGroupNamesCopy; } return this; } /** * Specifies the VPC Security Groups associated with the cache clusters * in the replication group.

This parameter can be used only with * replication group containing cache clusters running in an Amazon * Virtual Private Cloud (VPC). * * @return Specifies the VPC Security Groups associated with the cache clusters * in the replication group.

This parameter can be used only with * replication group containing cache clusters running in an Amazon * Virtual Private Cloud (VPC). */ public java.util.List getSecurityGroupIds() { if (securityGroupIds == null) { securityGroupIds = new com.amazonaws.internal.ListWithAutoConstructFlag(); securityGroupIds.setAutoConstruct(true); } return securityGroupIds; } /** * Specifies the VPC Security Groups associated with the cache clusters * in the replication group.

This parameter can be used only with * replication group containing cache clusters running in an Amazon * Virtual Private Cloud (VPC). * * @param securityGroupIds Specifies the VPC Security Groups associated with the cache clusters * in the replication group.

This parameter can be used only with * replication group containing cache clusters running in an Amazon * Virtual Private Cloud (VPC). */ public void setSecurityGroupIds(java.util.Collection securityGroupIds) { if (securityGroupIds == null) { this.securityGroupIds = null; return; } com.amazonaws.internal.ListWithAutoConstructFlag securityGroupIdsCopy = new com.amazonaws.internal.ListWithAutoConstructFlag(securityGroupIds.size()); securityGroupIdsCopy.addAll(securityGroupIds); this.securityGroupIds = securityGroupIdsCopy; } /** * Specifies the VPC Security Groups associated with the cache clusters * in the replication group.

This parameter can be used only with * replication group containing cache clusters running in an Amazon * Virtual Private Cloud (VPC). *

* Returns a reference to this object so that method calls can be chained together. * * @param securityGroupIds Specifies the VPC Security Groups associated with the cache clusters * in the replication group.

This parameter can be used only with * replication group containing cache clusters running in an Amazon * Virtual Private Cloud (VPC). * * @return A reference to this updated object so that method calls can be chained * together. */ public ModifyReplicationGroupRequest withSecurityGroupIds(String... securityGroupIds) { if (getSecurityGroupIds() == null) setSecurityGroupIds(new java.util.ArrayList(securityGroupIds.length)); for (String value : securityGroupIds) { getSecurityGroupIds().add(value); } return this; } /** * Specifies the VPC Security Groups associated with the cache clusters * in the replication group.

This parameter can be used only with * replication group containing cache clusters running in an Amazon * Virtual Private Cloud (VPC). *

* Returns a reference to this object so that method calls can be chained together. * * @param securityGroupIds Specifies the VPC Security Groups associated with the cache clusters * in the replication group.

This parameter can be used only with * replication group containing cache clusters running in an Amazon * Virtual Private Cloud (VPC). * * @return A reference to this updated object so that method calls can be chained * together. */ public ModifyReplicationGroupRequest withSecurityGroupIds(java.util.Collection securityGroupIds) { if (securityGroupIds == null) { this.securityGroupIds = null; } else { com.amazonaws.internal.ListWithAutoConstructFlag securityGroupIdsCopy = new com.amazonaws.internal.ListWithAutoConstructFlag(securityGroupIds.size()); securityGroupIdsCopy.addAll(securityGroupIds); this.securityGroupIds = securityGroupIdsCopy; } return this; } /** * The weekly time range (in UTC) during which replication group system * maintenance can occur. Note that system maintenance may result in an * outage. This change is made immediately. If you are moving this window * to the current time, there must be at least 120 minutes between the * current time and end of the window to ensure that pending changes are * applied. * * @return The weekly time range (in UTC) during which replication group system * maintenance can occur. Note that system maintenance may result in an * outage. This change is made immediately. If you are moving this window * to the current time, there must be at least 120 minutes between the * current time and end of the window to ensure that pending changes are * applied. */ public String getPreferredMaintenanceWindow() { return preferredMaintenanceWindow; } /** * The weekly time range (in UTC) during which replication group system * maintenance can occur. Note that system maintenance may result in an * outage. This change is made immediately. If you are moving this window * to the current time, there must be at least 120 minutes between the * current time and end of the window to ensure that pending changes are * applied. * * @param preferredMaintenanceWindow The weekly time range (in UTC) during which replication group system * maintenance can occur. Note that system maintenance may result in an * outage. This change is made immediately. If you are moving this window * to the current time, there must be at least 120 minutes between the * current time and end of the window to ensure that pending changes are * applied. */ public void setPreferredMaintenanceWindow(String preferredMaintenanceWindow) { this.preferredMaintenanceWindow = preferredMaintenanceWindow; } /** * The weekly time range (in UTC) during which replication group system * maintenance can occur. Note that system maintenance may result in an * outage. This change is made immediately. If you are moving this window * to the current time, there must be at least 120 minutes between the * current time and end of the window to ensure that pending changes are * applied. *

* Returns a reference to this object so that method calls can be chained together. * * @param preferredMaintenanceWindow The weekly time range (in UTC) during which replication group system * maintenance can occur. Note that system maintenance may result in an * outage. This change is made immediately. If you are moving this window * to the current time, there must be at least 120 minutes between the * current time and end of the window to ensure that pending changes are * applied. * * @return A reference to this updated object so that method calls can be chained * together. */ public ModifyReplicationGroupRequest withPreferredMaintenanceWindow(String preferredMaintenanceWindow) { this.preferredMaintenanceWindow = preferredMaintenanceWindow; return this; } /** * The Amazon Resource Name (ARN) of the Amazon SNS topic to which * notifications will be sent. The Amazon SNS topic owner must be * same as the replication group owner. * * @return The Amazon Resource Name (ARN) of the Amazon SNS topic to which * notifications will be sent. The Amazon SNS topic owner must be * same as the replication group owner. */ public String getNotificationTopicArn() { return notificationTopicArn; } /** * The Amazon Resource Name (ARN) of the Amazon SNS topic to which * notifications will be sent. The Amazon SNS topic owner must be * same as the replication group owner. * * @param notificationTopicArn The Amazon Resource Name (ARN) of the Amazon SNS topic to which * notifications will be sent. The Amazon SNS topic owner must be * same as the replication group owner. */ public void setNotificationTopicArn(String notificationTopicArn) { this.notificationTopicArn = notificationTopicArn; } /** * The Amazon Resource Name (ARN) of the Amazon SNS topic to which * notifications will be sent. The Amazon SNS topic owner must be * same as the replication group owner. *

* Returns a reference to this object so that method calls can be chained together. * * @param notificationTopicArn The Amazon Resource Name (ARN) of the Amazon SNS topic to which * notifications will be sent. The Amazon SNS topic owner must be * same as the replication group owner. * * @return A reference to this updated object so that method calls can be chained * together. */ public ModifyReplicationGroupRequest withNotificationTopicArn(String notificationTopicArn) { this.notificationTopicArn = notificationTopicArn; return this; } /** * The name of the cache parameter group to apply to all of the clusters * in this replication group. This change is asynchronously applied as * soon as possible for parameters when the ApplyImmediately * parameter is specified as true for this request. * * @return The name of the cache parameter group to apply to all of the clusters * in this replication group. This change is asynchronously applied as * soon as possible for parameters when the ApplyImmediately * parameter is specified as true for this request. */ public String getCacheParameterGroupName() { return cacheParameterGroupName; } /** * The name of the cache parameter group to apply to all of the clusters * in this replication group. This change is asynchronously applied as * soon as possible for parameters when the ApplyImmediately * parameter is specified as true for this request. * * @param cacheParameterGroupName The name of the cache parameter group to apply to all of the clusters * in this replication group. This change is asynchronously applied as * soon as possible for parameters when the ApplyImmediately * parameter is specified as true for this request. */ public void setCacheParameterGroupName(String cacheParameterGroupName) { this.cacheParameterGroupName = cacheParameterGroupName; } /** * The name of the cache parameter group to apply to all of the clusters * in this replication group. This change is asynchronously applied as * soon as possible for parameters when the ApplyImmediately * parameter is specified as true for this request. *

* Returns a reference to this object so that method calls can be chained together. * * @param cacheParameterGroupName The name of the cache parameter group to apply to all of the clusters * in this replication group. This change is asynchronously applied as * soon as possible for parameters when the ApplyImmediately * parameter is specified as true for this request. * * @return A reference to this updated object so that method calls can be chained * together. */ public ModifyReplicationGroupRequest withCacheParameterGroupName(String cacheParameterGroupName) { this.cacheParameterGroupName = cacheParameterGroupName; return this; } /** * The status of the Amazon SNS notification topic for the replication * group. Notifications are sent only if the status is active. *

Valid values: active | inactive * * @return The status of the Amazon SNS notification topic for the replication * group. Notifications are sent only if the status is active. *

Valid values: active | inactive */ public String getNotificationTopicStatus() { return notificationTopicStatus; } /** * The status of the Amazon SNS notification topic for the replication * group. Notifications are sent only if the status is active. *

Valid values: active | inactive * * @param notificationTopicStatus The status of the Amazon SNS notification topic for the replication * group. Notifications are sent only if the status is active. *

Valid values: active | inactive */ public void setNotificationTopicStatus(String notificationTopicStatus) { this.notificationTopicStatus = notificationTopicStatus; } /** * The status of the Amazon SNS notification topic for the replication * group. Notifications are sent only if the status is active. *

Valid values: active | inactive *

* Returns a reference to this object so that method calls can be chained together. * * @param notificationTopicStatus The status of the Amazon SNS notification topic for the replication * group. Notifications are sent only if the status is active. *

Valid values: active | inactive * * @return A reference to this updated object so that method calls can be chained * together. */ public ModifyReplicationGroupRequest withNotificationTopicStatus(String notificationTopicStatus) { this.notificationTopicStatus = notificationTopicStatus; return this; } /** * If true, this parameter causes the modifications in this * request and any pending modifications to be applied, asynchronously * and as soon as possible, regardless of the * PreferredMaintenanceWindow setting for the replication group. *

If false, then changes to the nodes in the replication * group are applied on the next maintenance reboot, or the next failure * reboot, whichever occurs first.

Valid values: true | * false

Default: false * * @return If true, this parameter causes the modifications in this * request and any pending modifications to be applied, asynchronously * and as soon as possible, regardless of the * PreferredMaintenanceWindow setting for the replication group. *

If false, then changes to the nodes in the replication * group are applied on the next maintenance reboot, or the next failure * reboot, whichever occurs first.

Valid values: true | * false

Default: false */ public Boolean isApplyImmediately() { return applyImmediately; } /** * If true, this parameter causes the modifications in this * request and any pending modifications to be applied, asynchronously * and as soon as possible, regardless of the * PreferredMaintenanceWindow setting for the replication group. *

If false, then changes to the nodes in the replication * group are applied on the next maintenance reboot, or the next failure * reboot, whichever occurs first.

Valid values: true | * false

Default: false * * @param applyImmediately If true, this parameter causes the modifications in this * request and any pending modifications to be applied, asynchronously * and as soon as possible, regardless of the * PreferredMaintenanceWindow setting for the replication group. *

If false, then changes to the nodes in the replication * group are applied on the next maintenance reboot, or the next failure * reboot, whichever occurs first.

Valid values: true | * false

Default: false */ public void setApplyImmediately(Boolean applyImmediately) { this.applyImmediately = applyImmediately; } /** * If true, this parameter causes the modifications in this * request and any pending modifications to be applied, asynchronously * and as soon as possible, regardless of the * PreferredMaintenanceWindow setting for the replication group. *

If false, then changes to the nodes in the replication * group are applied on the next maintenance reboot, or the next failure * reboot, whichever occurs first.

Valid values: true | * false

Default: false *

* Returns a reference to this object so that method calls can be chained together. * * @param applyImmediately If true, this parameter causes the modifications in this * request and any pending modifications to be applied, asynchronously * and as soon as possible, regardless of the * PreferredMaintenanceWindow setting for the replication group. *

If false, then changes to the nodes in the replication * group are applied on the next maintenance reboot, or the next failure * reboot, whichever occurs first.

Valid values: true | * false

Default: false * * @return A reference to this updated object so that method calls can be chained * together. */ public ModifyReplicationGroupRequest withApplyImmediately(Boolean applyImmediately) { this.applyImmediately = applyImmediately; return this; } /** * If true, this parameter causes the modifications in this * request and any pending modifications to be applied, asynchronously * and as soon as possible, regardless of the * PreferredMaintenanceWindow setting for the replication group. *

If false, then changes to the nodes in the replication * group are applied on the next maintenance reboot, or the next failure * reboot, whichever occurs first.

Valid values: true | * false

Default: false * * @return If true, this parameter causes the modifications in this * request and any pending modifications to be applied, asynchronously * and as soon as possible, regardless of the * PreferredMaintenanceWindow setting for the replication group. *

If false, then changes to the nodes in the replication * group are applied on the next maintenance reboot, or the next failure * reboot, whichever occurs first.

Valid values: true | * false

Default: false */ public Boolean getApplyImmediately() { return applyImmediately; } /** * The upgraded version of the cache engine to be run on the cache * clusters in the replication group. * * @return The upgraded version of the cache engine to be run on the cache * clusters in the replication group. */ public String getEngineVersion() { return engineVersion; } /** * The upgraded version of the cache engine to be run on the cache * clusters in the replication group. * * @param engineVersion The upgraded version of the cache engine to be run on the cache * clusters in the replication group. */ public void setEngineVersion(String engineVersion) { this.engineVersion = engineVersion; } /** * The upgraded version of the cache engine to be run on the cache * clusters in the replication group. *

* Returns a reference to this object so that method calls can be chained together. * * @param engineVersion The upgraded version of the cache engine to be run on the cache * clusters in the replication group. * * @return A reference to this updated object so that method calls can be chained * together. */ public ModifyReplicationGroupRequest withEngineVersion(String engineVersion) { this.engineVersion = engineVersion; return this; } /** * Determines whether minor engine upgrades will be applied automatically * to all of the clusters in the replication group during the maintenance * window. A value of true allows these upgrades to occur; * false disables automatic upgrades. * * @return Determines whether minor engine upgrades will be applied automatically * to all of the clusters in the replication group during the maintenance * window. A value of true allows these upgrades to occur; * false disables automatic upgrades. */ public Boolean isAutoMinorVersionUpgrade() { return autoMinorVersionUpgrade; } /** * Determines whether minor engine upgrades will be applied automatically * to all of the clusters in the replication group during the maintenance * window. A value of true allows these upgrades to occur; * false disables automatic upgrades. * * @param autoMinorVersionUpgrade Determines whether minor engine upgrades will be applied automatically * to all of the clusters in the replication group during the maintenance * window. A value of true allows these upgrades to occur; * false disables automatic upgrades. */ public void setAutoMinorVersionUpgrade(Boolean autoMinorVersionUpgrade) { this.autoMinorVersionUpgrade = autoMinorVersionUpgrade; } /** * Determines whether minor engine upgrades will be applied automatically * to all of the clusters in the replication group during the maintenance * window. A value of true allows these upgrades to occur; * false disables automatic upgrades. *

* Returns a reference to this object so that method calls can be chained together. * * @param autoMinorVersionUpgrade Determines whether minor engine upgrades will be applied automatically * to all of the clusters in the replication group during the maintenance * window. A value of true allows these upgrades to occur; * false disables automatic upgrades. * * @return A reference to this updated object so that method calls can be chained * together. */ public ModifyReplicationGroupRequest withAutoMinorVersionUpgrade(Boolean autoMinorVersionUpgrade) { this.autoMinorVersionUpgrade = autoMinorVersionUpgrade; return this; } /** * Determines whether minor engine upgrades will be applied automatically * to all of the clusters in the replication group during the maintenance * window. A value of true allows these upgrades to occur; * false disables automatic upgrades. * * @return Determines whether minor engine upgrades will be applied automatically * to all of the clusters in the replication group during the maintenance * window. A value of true allows these upgrades to occur; * false disables automatic upgrades. */ public Boolean getAutoMinorVersionUpgrade() { return autoMinorVersionUpgrade; } /** * The number of days for which ElastiCache will retain automatic node * group snapshots before deleting them. For example, if you set * SnapshotRetentionLimit to 5, then a snapshot that was taken * today will be retained for 5 days before being deleted. *

Important
If the value of SnapshotRetentionLimit is set * to zero (0), backups are turned off. * * @return The number of days for which ElastiCache will retain automatic node * group snapshots before deleting them. For example, if you set * SnapshotRetentionLimit to 5, then a snapshot that was taken * today will be retained for 5 days before being deleted. *

Important
If the value of SnapshotRetentionLimit is set * to zero (0), backups are turned off. */ public Integer getSnapshotRetentionLimit() { return snapshotRetentionLimit; } /** * The number of days for which ElastiCache will retain automatic node * group snapshots before deleting them. For example, if you set * SnapshotRetentionLimit to 5, then a snapshot that was taken * today will be retained for 5 days before being deleted. *

Important
If the value of SnapshotRetentionLimit is set * to zero (0), backups are turned off. * * @param snapshotRetentionLimit The number of days for which ElastiCache will retain automatic node * group snapshots before deleting them. For example, if you set * SnapshotRetentionLimit to 5, then a snapshot that was taken * today will be retained for 5 days before being deleted. *

Important
If the value of SnapshotRetentionLimit is set * to zero (0), backups are turned off. */ public void setSnapshotRetentionLimit(Integer snapshotRetentionLimit) { this.snapshotRetentionLimit = snapshotRetentionLimit; } /** * The number of days for which ElastiCache will retain automatic node * group snapshots before deleting them. For example, if you set * SnapshotRetentionLimit to 5, then a snapshot that was taken * today will be retained for 5 days before being deleted. *

Important
If the value of SnapshotRetentionLimit is set * to zero (0), backups are turned off. *

* Returns a reference to this object so that method calls can be chained together. * * @param snapshotRetentionLimit The number of days for which ElastiCache will retain automatic node * group snapshots before deleting them. For example, if you set * SnapshotRetentionLimit to 5, then a snapshot that was taken * today will be retained for 5 days before being deleted. *

Important
If the value of SnapshotRetentionLimit is set * to zero (0), backups are turned off. * * @return A reference to this updated object so that method calls can be chained * together. */ public ModifyReplicationGroupRequest withSnapshotRetentionLimit(Integer snapshotRetentionLimit) { this.snapshotRetentionLimit = snapshotRetentionLimit; return this; } /** * The daily time range (in UTC) during which ElastiCache will begin * taking a daily snapshot of the node group specified by * SnapshottingClusterId.

Example: 05:00-09:00 *

If you do not specify this parameter, then ElastiCache will * automatically choose an appropriate time range. * * @return The daily time range (in UTC) during which ElastiCache will begin * taking a daily snapshot of the node group specified by * SnapshottingClusterId.

Example: 05:00-09:00 *

If you do not specify this parameter, then ElastiCache will * automatically choose an appropriate time range. */ public String getSnapshotWindow() { return snapshotWindow; } /** * The daily time range (in UTC) during which ElastiCache will begin * taking a daily snapshot of the node group specified by * SnapshottingClusterId.

Example: 05:00-09:00 *

If you do not specify this parameter, then ElastiCache will * automatically choose an appropriate time range. * * @param snapshotWindow The daily time range (in UTC) during which ElastiCache will begin * taking a daily snapshot of the node group specified by * SnapshottingClusterId.

Example: 05:00-09:00 *

If you do not specify this parameter, then ElastiCache will * automatically choose an appropriate time range. */ public void setSnapshotWindow(String snapshotWindow) { this.snapshotWindow = snapshotWindow; } /** * The daily time range (in UTC) during which ElastiCache will begin * taking a daily snapshot of the node group specified by * SnapshottingClusterId.

Example: 05:00-09:00 *

If you do not specify this parameter, then ElastiCache will * automatically choose an appropriate time range. *

* Returns a reference to this object so that method calls can be chained together. * * @param snapshotWindow The daily time range (in UTC) during which ElastiCache will begin * taking a daily snapshot of the node group specified by * SnapshottingClusterId.

Example: 05:00-09:00 *

If you do not specify this parameter, then ElastiCache will * automatically choose an appropriate time range. * * @return A reference to this updated object so that method calls can be chained * together. */ public ModifyReplicationGroupRequest withSnapshotWindow(String snapshotWindow) { this.snapshotWindow = snapshotWindow; return this; } /** * Returns a string representation of this object; useful for testing and * debugging. * * @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: " + getReplicationGroupId() + ","); if (getReplicationGroupDescription() != null) sb.append("ReplicationGroupDescription: " + getReplicationGroupDescription() + ","); if (getPrimaryClusterId() != null) sb.append("PrimaryClusterId: " + getPrimaryClusterId() + ","); if (getSnapshottingClusterId() != null) sb.append("SnapshottingClusterId: " + getSnapshottingClusterId() + ","); if (isAutomaticFailoverEnabled() != null) sb.append("AutomaticFailoverEnabled: " + isAutomaticFailoverEnabled() + ","); if (getCacheSecurityGroupNames() != null) sb.append("CacheSecurityGroupNames: " + getCacheSecurityGroupNames() + ","); if (getSecurityGroupIds() != null) sb.append("SecurityGroupIds: " + getSecurityGroupIds() + ","); if (getPreferredMaintenanceWindow() != null) sb.append("PreferredMaintenanceWindow: " + getPreferredMaintenanceWindow() + ","); if (getNotificationTopicArn() != null) sb.append("NotificationTopicArn: " + getNotificationTopicArn() + ","); if (getCacheParameterGroupName() != null) sb.append("CacheParameterGroupName: " + getCacheParameterGroupName() + ","); if (getNotificationTopicStatus() != null) sb.append("NotificationTopicStatus: " + getNotificationTopicStatus() + ","); if (isApplyImmediately() != null) sb.append("ApplyImmediately: " + isApplyImmediately() + ","); if (getEngineVersion() != null) sb.append("EngineVersion: " + getEngineVersion() + ","); if (isAutoMinorVersionUpgrade() != null) sb.append("AutoMinorVersionUpgrade: " + isAutoMinorVersionUpgrade() + ","); if (getSnapshotRetentionLimit() != null) sb.append("SnapshotRetentionLimit: " + getSnapshotRetentionLimit() + ","); if (getSnapshotWindow() != null) sb.append("SnapshotWindow: " + getSnapshotWindow() ); sb.append("}"); return sb.toString(); } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getReplicationGroupId() == null) ? 0 : getReplicationGroupId().hashCode()); hashCode = prime * hashCode + ((getReplicationGroupDescription() == null) ? 0 : getReplicationGroupDescription().hashCode()); hashCode = prime * hashCode + ((getPrimaryClusterId() == null) ? 0 : getPrimaryClusterId().hashCode()); hashCode = prime * hashCode + ((getSnapshottingClusterId() == null) ? 0 : getSnapshottingClusterId().hashCode()); hashCode = prime * hashCode + ((isAutomaticFailoverEnabled() == null) ? 0 : isAutomaticFailoverEnabled().hashCode()); hashCode = prime * hashCode + ((getCacheSecurityGroupNames() == null) ? 0 : getCacheSecurityGroupNames().hashCode()); hashCode = prime * hashCode + ((getSecurityGroupIds() == null) ? 0 : getSecurityGroupIds().hashCode()); hashCode = prime * hashCode + ((getPreferredMaintenanceWindow() == null) ? 0 : getPreferredMaintenanceWindow().hashCode()); hashCode = prime * hashCode + ((getNotificationTopicArn() == null) ? 0 : getNotificationTopicArn().hashCode()); hashCode = prime * hashCode + ((getCacheParameterGroupName() == null) ? 0 : getCacheParameterGroupName().hashCode()); hashCode = prime * hashCode + ((getNotificationTopicStatus() == null) ? 0 : getNotificationTopicStatus().hashCode()); hashCode = prime * hashCode + ((isApplyImmediately() == null) ? 0 : isApplyImmediately().hashCode()); hashCode = prime * hashCode + ((getEngineVersion() == null) ? 0 : getEngineVersion().hashCode()); hashCode = prime * hashCode + ((isAutoMinorVersionUpgrade() == null) ? 0 : isAutoMinorVersionUpgrade().hashCode()); hashCode = prime * hashCode + ((getSnapshotRetentionLimit() == null) ? 0 : getSnapshotRetentionLimit().hashCode()); hashCode = prime * hashCode + ((getSnapshotWindow() == null) ? 0 : getSnapshotWindow().hashCode()); return hashCode; } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof ModifyReplicationGroupRequest == false) return false; ModifyReplicationGroupRequest other = (ModifyReplicationGroupRequest)obj; if (other.getReplicationGroupId() == null ^ this.getReplicationGroupId() == null) return false; if (other.getReplicationGroupId() != null && other.getReplicationGroupId().equals(this.getReplicationGroupId()) == false) return false; if (other.getReplicationGroupDescription() == null ^ this.getReplicationGroupDescription() == null) return false; if (other.getReplicationGroupDescription() != null && other.getReplicationGroupDescription().equals(this.getReplicationGroupDescription()) == false) return false; if (other.getPrimaryClusterId() == null ^ this.getPrimaryClusterId() == null) return false; if (other.getPrimaryClusterId() != null && other.getPrimaryClusterId().equals(this.getPrimaryClusterId()) == false) return false; if (other.getSnapshottingClusterId() == null ^ this.getSnapshottingClusterId() == null) return false; if (other.getSnapshottingClusterId() != null && other.getSnapshottingClusterId().equals(this.getSnapshottingClusterId()) == false) return false; if (other.isAutomaticFailoverEnabled() == null ^ this.isAutomaticFailoverEnabled() == null) return false; if (other.isAutomaticFailoverEnabled() != null && other.isAutomaticFailoverEnabled().equals(this.isAutomaticFailoverEnabled()) == false) return false; if (other.getCacheSecurityGroupNames() == null ^ this.getCacheSecurityGroupNames() == null) return false; if (other.getCacheSecurityGroupNames() != null && other.getCacheSecurityGroupNames().equals(this.getCacheSecurityGroupNames()) == false) return false; if (other.getSecurityGroupIds() == null ^ this.getSecurityGroupIds() == null) return false; if (other.getSecurityGroupIds() != null && other.getSecurityGroupIds().equals(this.getSecurityGroupIds()) == false) return false; if (other.getPreferredMaintenanceWindow() == null ^ this.getPreferredMaintenanceWindow() == null) return false; if (other.getPreferredMaintenanceWindow() != null && other.getPreferredMaintenanceWindow().equals(this.getPreferredMaintenanceWindow()) == false) return false; if (other.getNotificationTopicArn() == null ^ this.getNotificationTopicArn() == null) return false; if (other.getNotificationTopicArn() != null && other.getNotificationTopicArn().equals(this.getNotificationTopicArn()) == false) return false; if (other.getCacheParameterGroupName() == null ^ this.getCacheParameterGroupName() == null) return false; if (other.getCacheParameterGroupName() != null && other.getCacheParameterGroupName().equals(this.getCacheParameterGroupName()) == false) return false; if (other.getNotificationTopicStatus() == null ^ this.getNotificationTopicStatus() == null) return false; if (other.getNotificationTopicStatus() != null && other.getNotificationTopicStatus().equals(this.getNotificationTopicStatus()) == false) return false; if (other.isApplyImmediately() == null ^ this.isApplyImmediately() == null) return false; if (other.isApplyImmediately() != null && other.isApplyImmediately().equals(this.isApplyImmediately()) == false) return false; if (other.getEngineVersion() == null ^ this.getEngineVersion() == null) return false; if (other.getEngineVersion() != null && other.getEngineVersion().equals(this.getEngineVersion()) == false) return false; if (other.isAutoMinorVersionUpgrade() == null ^ this.isAutoMinorVersionUpgrade() == null) return false; if (other.isAutoMinorVersionUpgrade() != null && other.isAutoMinorVersionUpgrade().equals(this.isAutoMinorVersionUpgrade()) == false) return false; if (other.getSnapshotRetentionLimit() == null ^ this.getSnapshotRetentionLimit() == null) return false; if (other.getSnapshotRetentionLimit() != null && other.getSnapshotRetentionLimit().equals(this.getSnapshotRetentionLimit()) == false) return false; if (other.getSnapshotWindow() == null ^ this.getSnapshotWindow() == null) return false; if (other.getSnapshotWindow() != null && other.getSnapshotWindow().equals(this.getSnapshotWindow()) == false) return false; return true; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy