modifyReplicationGroup method

Future<ModifyReplicationGroupResult> modifyReplicationGroup({
  1. required String replicationGroupId,
  2. bool? applyImmediately,
  3. String? authToken,
  4. AuthTokenUpdateStrategyType? authTokenUpdateStrategy,
  5. bool? autoMinorVersionUpgrade,
  6. bool? automaticFailoverEnabled,
  7. String? cacheNodeType,
  8. String? cacheParameterGroupName,
  9. List<String>? cacheSecurityGroupNames,
  10. String? engineVersion,
  11. bool? multiAZEnabled,
  12. String? nodeGroupId,
  13. String? notificationTopicArn,
  14. String? notificationTopicStatus,
  15. String? preferredMaintenanceWindow,
  16. String? primaryClusterId,
  17. bool? removeUserGroups,
  18. String? replicationGroupDescription,
  19. List<String>? securityGroupIds,
  20. int? snapshotRetentionLimit,
  21. String? snapshotWindow,
  22. String? snapshottingClusterId,
  23. List<String>? userGroupIdsToAdd,
  24. List<String>? userGroupIdsToRemove,
})

Modifies the settings for a replication group.

May throw ReplicationGroupNotFoundFault. May throw InvalidReplicationGroupStateFault. May throw InvalidUserGroupStateFault. May throw UserGroupNotFoundFault. May throw InvalidCacheClusterStateFault. May throw InvalidCacheSecurityGroupStateFault. May throw InsufficientCacheClusterCapacityFault. May throw CacheClusterNotFoundFault. May throw NodeQuotaForClusterExceededFault. May throw NodeQuotaForCustomerExceededFault. May throw CacheSecurityGroupNotFoundFault. May throw CacheParameterGroupNotFoundFault. May throw InvalidVPCNetworkStateFault. May throw InvalidKMSKeyFault. May throw InvalidParameterValueException. May throw InvalidParameterCombinationException.

Parameter replicationGroupId : The identifier of the replication group to modify.

Parameter 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, 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

Parameter authToken : Reserved parameter. The password used to access a password protected server. This parameter must be specified with the auth-token-update-strategy parameter. Password constraints:

  • Must be only printable ASCII characters
  • Must be at least 16 characters and no more than 128 characters in length
  • Cannot contain any of the following characters: '/', '"', or '@', '%'
For more information, see AUTH password at AUTH.

Parameter authTokenUpdateStrategy : Specifies the strategy to use to update the AUTH token. This parameter must be specified with the auth-token parameter. Possible values:

  • Rotate
  • Set
For more information, see Authenticating Users with Redis AUTH

Parameter autoMinorVersionUpgrade : This parameter is currently disabled.

Parameter automaticFailoverEnabled : Determines whether a read replica is automatically promoted to read/write primary if the existing primary encounters a failure.

Valid values: true | false

Parameter cacheNodeType : A valid cache node type that you want to scale this replication group to.

Parameter 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.

Parameter 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 clusters running outside of an Amazon Virtual Private Cloud (Amazon VPC).

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

Parameter engineVersion : The upgraded version of the cache engine to be run on the clusters in the replication group.

Important: You can upgrade to a newer engine version (see Selecting a Cache Engine and Version), but you cannot downgrade to an earlier engine version. If you want to use an earlier engine version, you must delete the existing replication group and create it anew with the earlier engine version.

Parameter multiAZEnabled : A flag indicating if you have Multi-AZ enabled to enhance fault tolerance. For more information, see Minimizing Downtime: Multi-AZ.

Parameter nodeGroupId : Deprecated. This parameter is not used.

Parameter notificationTopicArn : The Amazon Resource Name (ARN) of the Amazon SNS topic to which notifications are sent.

Parameter 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

Parameter preferredMaintenanceWindow : Specifies the weekly time range during which maintenance on the cluster is performed. It is specified as a range in the format ddd:hh24:mi-ddd:hh24:mi (24H Clock UTC). The minimum maintenance window is a 60 minute period.

Valid values for ddd are:

  • sun
  • mon
  • tue
  • wed
  • thu
  • fri
  • sat
Example: sun:23:00-mon:01:30

Parameter primaryClusterId : For replication groups with a single primary, if this parameter is specified, ElastiCache promotes the specified cluster in the specified replication group to the primary role. The nodes of all other clusters in the replication group are read replicas.

Parameter removeUserGroups : Removes the user groups that can access this replication group.

Parameter replicationGroupDescription : A description for the replication group. Maximum length is 255 characters.

Parameter securityGroupIds : Specifies the VPC Security Groups associated with the clusters in the replication group.

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

Parameter snapshotRetentionLimit : The number of days for which ElastiCache retains automatic node group (shard) snapshots before deleting them. For example, if you set SnapshotRetentionLimit to 5, a snapshot that was taken today is retained for 5 days before being deleted.

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

Parameter snapshotWindow : The daily time range (in UTC) during which ElastiCache begins taking a daily snapshot of the node group (shard) specified by SnapshottingClusterId.

Example: 05:00-09:00

If you do not specify this parameter, ElastiCache automatically chooses an appropriate time range.

Parameter snapshottingClusterId : The cluster ID that is used as the daily snapshot source for the replication group. This parameter cannot be set for Redis (cluster mode enabled) replication groups.

Parameter userGroupIdsToAdd : A list of user group IDs.

Parameter userGroupIdsToRemove : A list of users groups to remove, meaning the users in the group no longer can access thereplication group.

Implementation

Future<ModifyReplicationGroupResult> modifyReplicationGroup({
  required String replicationGroupId,
  bool? applyImmediately,
  String? authToken,
  AuthTokenUpdateStrategyType? authTokenUpdateStrategy,
  bool? autoMinorVersionUpgrade,
  bool? automaticFailoverEnabled,
  String? cacheNodeType,
  String? cacheParameterGroupName,
  List<String>? cacheSecurityGroupNames,
  String? engineVersion,
  bool? multiAZEnabled,
  String? nodeGroupId,
  String? notificationTopicArn,
  String? notificationTopicStatus,
  String? preferredMaintenanceWindow,
  String? primaryClusterId,
  bool? removeUserGroups,
  String? replicationGroupDescription,
  List<String>? securityGroupIds,
  int? snapshotRetentionLimit,
  String? snapshotWindow,
  String? snapshottingClusterId,
  List<String>? userGroupIdsToAdd,
  List<String>? userGroupIdsToRemove,
}) async {
  ArgumentError.checkNotNull(replicationGroupId, 'replicationGroupId');
  final $request = <String, dynamic>{};
  $request['ReplicationGroupId'] = replicationGroupId;
  applyImmediately?.also((arg) => $request['ApplyImmediately'] = arg);
  authToken?.also((arg) => $request['AuthToken'] = arg);
  authTokenUpdateStrategy
      ?.also((arg) => $request['AuthTokenUpdateStrategy'] = arg.toValue());
  autoMinorVersionUpgrade
      ?.also((arg) => $request['AutoMinorVersionUpgrade'] = arg);
  automaticFailoverEnabled
      ?.also((arg) => $request['AutomaticFailoverEnabled'] = arg);
  cacheNodeType?.also((arg) => $request['CacheNodeType'] = arg);
  cacheParameterGroupName
      ?.also((arg) => $request['CacheParameterGroupName'] = arg);
  cacheSecurityGroupNames
      ?.also((arg) => $request['CacheSecurityGroupNames'] = arg);
  engineVersion?.also((arg) => $request['EngineVersion'] = arg);
  multiAZEnabled?.also((arg) => $request['MultiAZEnabled'] = arg);
  nodeGroupId?.also((arg) => $request['NodeGroupId'] = arg);
  notificationTopicArn?.also((arg) => $request['NotificationTopicArn'] = arg);
  notificationTopicStatus
      ?.also((arg) => $request['NotificationTopicStatus'] = arg);
  preferredMaintenanceWindow
      ?.also((arg) => $request['PreferredMaintenanceWindow'] = arg);
  primaryClusterId?.also((arg) => $request['PrimaryClusterId'] = arg);
  removeUserGroups?.also((arg) => $request['RemoveUserGroups'] = arg);
  replicationGroupDescription
      ?.also((arg) => $request['ReplicationGroupDescription'] = arg);
  securityGroupIds?.also((arg) => $request['SecurityGroupIds'] = arg);
  snapshotRetentionLimit
      ?.also((arg) => $request['SnapshotRetentionLimit'] = arg);
  snapshotWindow?.also((arg) => $request['SnapshotWindow'] = arg);
  snapshottingClusterId
      ?.also((arg) => $request['SnapshottingClusterId'] = arg);
  userGroupIdsToAdd?.also((arg) => $request['UserGroupIdsToAdd'] = arg);
  userGroupIdsToRemove?.also((arg) => $request['UserGroupIdsToRemove'] = arg);
  final $result = await _protocol.send(
    $request,
    action: 'ModifyReplicationGroup',
    version: '2015-02-02',
    method: 'POST',
    requestUri: '/',
    exceptionFnMap: _exceptionFns,
    shape: shapes['ModifyReplicationGroupMessage'],
    shapes: shapes,
    resultWrapper: 'ModifyReplicationGroupResult',
  );
  return ModifyReplicationGroupResult.fromXml($result);
}