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

software.amazon.awssdk.services.redshift.model.ModifyClusterRequest Maven / Gradle / Ivy

/*
 * Copyright 2014-2019 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 software.amazon.awssdk.services.redshift.model;

import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.function.BiConsumer;
import java.util.function.Consumer;
import java.util.function.Function;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.awscore.AwsRequestOverrideConfiguration;
import software.amazon.awssdk.core.SdkField;
import software.amazon.awssdk.core.SdkPojo;
import software.amazon.awssdk.core.protocol.MarshallLocation;
import software.amazon.awssdk.core.protocol.MarshallingType;
import software.amazon.awssdk.core.traits.ListTrait;
import software.amazon.awssdk.core.traits.LocationTrait;
import software.amazon.awssdk.core.util.DefaultSdkAutoConstructList;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;

/**
 * 

*/ @Generated("software.amazon.awssdk:codegen") public final class ModifyClusterRequest extends RedshiftRequest implements ToCopyableBuilder { private static final SdkField CLUSTER_IDENTIFIER_FIELD = SdkField. builder(MarshallingType.STRING) .getter(getter(ModifyClusterRequest::clusterIdentifier)).setter(setter(Builder::clusterIdentifier)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ClusterIdentifier").build()).build(); private static final SdkField CLUSTER_TYPE_FIELD = SdkField. builder(MarshallingType.STRING) .getter(getter(ModifyClusterRequest::clusterType)).setter(setter(Builder::clusterType)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ClusterType").build()).build(); private static final SdkField NODE_TYPE_FIELD = SdkField. builder(MarshallingType.STRING) .getter(getter(ModifyClusterRequest::nodeType)).setter(setter(Builder::nodeType)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("NodeType").build()).build(); private static final SdkField NUMBER_OF_NODES_FIELD = SdkField. builder(MarshallingType.INTEGER) .getter(getter(ModifyClusterRequest::numberOfNodes)).setter(setter(Builder::numberOfNodes)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("NumberOfNodes").build()).build(); private static final SdkField> CLUSTER_SECURITY_GROUPS_FIELD = SdkField .> builder(MarshallingType.LIST) .getter(getter(ModifyClusterRequest::clusterSecurityGroups)) .setter(setter(Builder::clusterSecurityGroups)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ClusterSecurityGroups").build(), ListTrait .builder() .memberLocationName("ClusterSecurityGroupName") .memberFieldInfo( SdkField. builder(MarshallingType.STRING) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD) .locationName("ClusterSecurityGroupName").build()).build()).build()).build(); private static final SdkField> VPC_SECURITY_GROUP_IDS_FIELD = SdkField .> builder(MarshallingType.LIST) .getter(getter(ModifyClusterRequest::vpcSecurityGroupIds)) .setter(setter(Builder::vpcSecurityGroupIds)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("VpcSecurityGroupIds").build(), ListTrait .builder() .memberLocationName("VpcSecurityGroupId") .memberFieldInfo( SdkField. builder(MarshallingType.STRING) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD) .locationName("VpcSecurityGroupId").build()).build()).build()).build(); private static final SdkField MASTER_USER_PASSWORD_FIELD = SdkField. builder(MarshallingType.STRING) .getter(getter(ModifyClusterRequest::masterUserPassword)).setter(setter(Builder::masterUserPassword)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("MasterUserPassword").build()) .build(); private static final SdkField CLUSTER_PARAMETER_GROUP_NAME_FIELD = SdkField. builder(MarshallingType.STRING) .getter(getter(ModifyClusterRequest::clusterParameterGroupName)).setter(setter(Builder::clusterParameterGroupName)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ClusterParameterGroupName").build()) .build(); private static final SdkField AUTOMATED_SNAPSHOT_RETENTION_PERIOD_FIELD = SdkField . builder(MarshallingType.INTEGER) .getter(getter(ModifyClusterRequest::automatedSnapshotRetentionPeriod)) .setter(setter(Builder::automatedSnapshotRetentionPeriod)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("AutomatedSnapshotRetentionPeriod") .build()).build(); private static final SdkField MANUAL_SNAPSHOT_RETENTION_PERIOD_FIELD = SdkField . builder(MarshallingType.INTEGER) .getter(getter(ModifyClusterRequest::manualSnapshotRetentionPeriod)) .setter(setter(Builder::manualSnapshotRetentionPeriod)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ManualSnapshotRetentionPeriod") .build()).build(); private static final SdkField PREFERRED_MAINTENANCE_WINDOW_FIELD = SdkField . builder(MarshallingType.STRING) .getter(getter(ModifyClusterRequest::preferredMaintenanceWindow)) .setter(setter(Builder::preferredMaintenanceWindow)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("PreferredMaintenanceWindow").build()) .build(); private static final SdkField CLUSTER_VERSION_FIELD = SdkField. builder(MarshallingType.STRING) .getter(getter(ModifyClusterRequest::clusterVersion)).setter(setter(Builder::clusterVersion)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ClusterVersion").build()).build(); private static final SdkField ALLOW_VERSION_UPGRADE_FIELD = SdkField. builder(MarshallingType.BOOLEAN) .getter(getter(ModifyClusterRequest::allowVersionUpgrade)).setter(setter(Builder::allowVersionUpgrade)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("AllowVersionUpgrade").build()) .build(); private static final SdkField HSM_CLIENT_CERTIFICATE_IDENTIFIER_FIELD = SdkField . builder(MarshallingType.STRING) .getter(getter(ModifyClusterRequest::hsmClientCertificateIdentifier)) .setter(setter(Builder::hsmClientCertificateIdentifier)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("HsmClientCertificateIdentifier") .build()).build(); private static final SdkField HSM_CONFIGURATION_IDENTIFIER_FIELD = SdkField . builder(MarshallingType.STRING) .getter(getter(ModifyClusterRequest::hsmConfigurationIdentifier)) .setter(setter(Builder::hsmConfigurationIdentifier)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("HsmConfigurationIdentifier").build()) .build(); private static final SdkField NEW_CLUSTER_IDENTIFIER_FIELD = SdkField. builder(MarshallingType.STRING) .getter(getter(ModifyClusterRequest::newClusterIdentifier)).setter(setter(Builder::newClusterIdentifier)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("NewClusterIdentifier").build()) .build(); private static final SdkField PUBLICLY_ACCESSIBLE_FIELD = SdkField. builder(MarshallingType.BOOLEAN) .getter(getter(ModifyClusterRequest::publiclyAccessible)).setter(setter(Builder::publiclyAccessible)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("PubliclyAccessible").build()) .build(); private static final SdkField ELASTIC_IP_FIELD = SdkField. builder(MarshallingType.STRING) .getter(getter(ModifyClusterRequest::elasticIp)).setter(setter(Builder::elasticIp)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ElasticIp").build()).build(); private static final SdkField ENHANCED_VPC_ROUTING_FIELD = SdkField. builder(MarshallingType.BOOLEAN) .getter(getter(ModifyClusterRequest::enhancedVpcRouting)).setter(setter(Builder::enhancedVpcRouting)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("EnhancedVpcRouting").build()) .build(); private static final SdkField MAINTENANCE_TRACK_NAME_FIELD = SdkField. builder(MarshallingType.STRING) .getter(getter(ModifyClusterRequest::maintenanceTrackName)).setter(setter(Builder::maintenanceTrackName)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("MaintenanceTrackName").build()) .build(); private static final SdkField ENCRYPTED_FIELD = SdkField. builder(MarshallingType.BOOLEAN) .getter(getter(ModifyClusterRequest::encrypted)).setter(setter(Builder::encrypted)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Encrypted").build()).build(); private static final SdkField KMS_KEY_ID_FIELD = SdkField. builder(MarshallingType.STRING) .getter(getter(ModifyClusterRequest::kmsKeyId)).setter(setter(Builder::kmsKeyId)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("KmsKeyId").build()).build(); private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(CLUSTER_IDENTIFIER_FIELD, CLUSTER_TYPE_FIELD, NODE_TYPE_FIELD, NUMBER_OF_NODES_FIELD, CLUSTER_SECURITY_GROUPS_FIELD, VPC_SECURITY_GROUP_IDS_FIELD, MASTER_USER_PASSWORD_FIELD, CLUSTER_PARAMETER_GROUP_NAME_FIELD, AUTOMATED_SNAPSHOT_RETENTION_PERIOD_FIELD, MANUAL_SNAPSHOT_RETENTION_PERIOD_FIELD, PREFERRED_MAINTENANCE_WINDOW_FIELD, CLUSTER_VERSION_FIELD, ALLOW_VERSION_UPGRADE_FIELD, HSM_CLIENT_CERTIFICATE_IDENTIFIER_FIELD, HSM_CONFIGURATION_IDENTIFIER_FIELD, NEW_CLUSTER_IDENTIFIER_FIELD, PUBLICLY_ACCESSIBLE_FIELD, ELASTIC_IP_FIELD, ENHANCED_VPC_ROUTING_FIELD, MAINTENANCE_TRACK_NAME_FIELD, ENCRYPTED_FIELD, KMS_KEY_ID_FIELD)); private final String clusterIdentifier; private final String clusterType; private final String nodeType; private final Integer numberOfNodes; private final List clusterSecurityGroups; private final List vpcSecurityGroupIds; private final String masterUserPassword; private final String clusterParameterGroupName; private final Integer automatedSnapshotRetentionPeriod; private final Integer manualSnapshotRetentionPeriod; private final String preferredMaintenanceWindow; private final String clusterVersion; private final Boolean allowVersionUpgrade; private final String hsmClientCertificateIdentifier; private final String hsmConfigurationIdentifier; private final String newClusterIdentifier; private final Boolean publiclyAccessible; private final String elasticIp; private final Boolean enhancedVpcRouting; private final String maintenanceTrackName; private final Boolean encrypted; private final String kmsKeyId; private ModifyClusterRequest(BuilderImpl builder) { super(builder); this.clusterIdentifier = builder.clusterIdentifier; this.clusterType = builder.clusterType; this.nodeType = builder.nodeType; this.numberOfNodes = builder.numberOfNodes; this.clusterSecurityGroups = builder.clusterSecurityGroups; this.vpcSecurityGroupIds = builder.vpcSecurityGroupIds; this.masterUserPassword = builder.masterUserPassword; this.clusterParameterGroupName = builder.clusterParameterGroupName; this.automatedSnapshotRetentionPeriod = builder.automatedSnapshotRetentionPeriod; this.manualSnapshotRetentionPeriod = builder.manualSnapshotRetentionPeriod; this.preferredMaintenanceWindow = builder.preferredMaintenanceWindow; this.clusterVersion = builder.clusterVersion; this.allowVersionUpgrade = builder.allowVersionUpgrade; this.hsmClientCertificateIdentifier = builder.hsmClientCertificateIdentifier; this.hsmConfigurationIdentifier = builder.hsmConfigurationIdentifier; this.newClusterIdentifier = builder.newClusterIdentifier; this.publiclyAccessible = builder.publiclyAccessible; this.elasticIp = builder.elasticIp; this.enhancedVpcRouting = builder.enhancedVpcRouting; this.maintenanceTrackName = builder.maintenanceTrackName; this.encrypted = builder.encrypted; this.kmsKeyId = builder.kmsKeyId; } /** *

* The unique identifier of the cluster to be modified. *

*

* Example: examplecluster *

* * @return The unique identifier of the cluster to be modified.

*

* Example: examplecluster */ public String clusterIdentifier() { return clusterIdentifier; } /** *

* The new cluster type. *

*

* When you submit your cluster resize request, your existing cluster goes into a read-only mode. After Amazon * Redshift provisions a new cluster based on your resize requirements, there will be outage for a period while the * old cluster is deleted and your connection is switched to the new cluster. You can use DescribeResize to * track the progress of the resize request. *

*

* Valid Values: multi-node | single-node *

* * @return The new cluster type.

*

* When you submit your cluster resize request, your existing cluster goes into a read-only mode. After * Amazon Redshift provisions a new cluster based on your resize requirements, there will be outage for a * period while the old cluster is deleted and your connection is switched to the new cluster. You can use * DescribeResize to track the progress of the resize request. *

*

* Valid Values: multi-node | single-node */ public String clusterType() { return clusterType; } /** *

* The new node type of the cluster. If you specify a new node type, you must also specify the number of nodes * parameter. *

*

* When you submit your request to resize a cluster, Amazon Redshift sets access permissions for the cluster to * read-only. After Amazon Redshift provisions a new cluster according to your resize requirements, there will be a * temporary outage while the old cluster is deleted and your connection is switched to the new cluster. When the * new connection is complete, the original access permissions for the cluster are restored. You can use * DescribeResize to track the progress of the resize request. *

*

* Valid Values: ds2.xlarge | ds2.8xlarge | dc1.large | * dc1.8xlarge | dc2.large | dc2.8xlarge *

* * @return The new node type of the cluster. If you specify a new node type, you must also specify the number of * nodes parameter.

*

* When you submit your request to resize a cluster, Amazon Redshift sets access permissions for the cluster * to read-only. After Amazon Redshift provisions a new cluster according to your resize requirements, there * will be a temporary outage while the old cluster is deleted and your connection is switched to the new * cluster. When the new connection is complete, the original access permissions for the cluster are * restored. You can use DescribeResize to track the progress of the resize request. *

*

* Valid Values: ds2.xlarge | ds2.8xlarge | dc1.large | * dc1.8xlarge | dc2.large | dc2.8xlarge */ public String nodeType() { return nodeType; } /** *

* The new number of nodes of the cluster. If you specify a new number of nodes, you must also specify the node type * parameter. *

*

* When you submit your request to resize a cluster, Amazon Redshift sets access permissions for the cluster to * read-only. After Amazon Redshift provisions a new cluster according to your resize requirements, there will be a * temporary outage while the old cluster is deleted and your connection is switched to the new cluster. When the * new connection is complete, the original access permissions for the cluster are restored. You can use * DescribeResize to track the progress of the resize request. *

*

* Valid Values: Integer greater than 0. *

* * @return The new number of nodes of the cluster. If you specify a new number of nodes, you must also specify the * node type parameter.

*

* When you submit your request to resize a cluster, Amazon Redshift sets access permissions for the cluster * to read-only. After Amazon Redshift provisions a new cluster according to your resize requirements, there * will be a temporary outage while the old cluster is deleted and your connection is switched to the new * cluster. When the new connection is complete, the original access permissions for the cluster are * restored. You can use DescribeResize to track the progress of the resize request. *

*

* Valid Values: Integer greater than 0. */ public Integer numberOfNodes() { return numberOfNodes; } /** *

* A list of cluster security groups to be authorized on this cluster. This change is asynchronously applied as soon * as possible. *

*

* Security groups currently associated with the cluster, and not in the list of groups to apply, will be revoked * from the cluster. *

*

* Constraints: *

*
    *
  • *

    * Must be 1 to 255 alphanumeric characters or hyphens *

    *
  • *
  • *

    * First character must be a letter *

    *
  • *
  • *

    * Cannot end with a hyphen or contain two consecutive hyphens *

    *
  • *
*

* Attempts to modify the collection returned by this method will result in an UnsupportedOperationException. *

* * @return A list of cluster security groups to be authorized on this cluster. This change is asynchronously applied * as soon as possible.

*

* Security groups currently associated with the cluster, and not in the list of groups to apply, will be * revoked from the cluster. *

*

* Constraints: *

*
    *
  • *

    * Must be 1 to 255 alphanumeric characters or hyphens *

    *
  • *
  • *

    * First character must be a letter *

    *
  • *
  • *

    * Cannot end with a hyphen or contain two consecutive hyphens *

    *
  • */ public List clusterSecurityGroups() { return clusterSecurityGroups; } /** *

    * A list of virtual private cloud (VPC) security groups to be associated with the cluster. This change is * asynchronously applied as soon as possible. *

    *

    * Attempts to modify the collection returned by this method will result in an UnsupportedOperationException. *

    * * @return A list of virtual private cloud (VPC) security groups to be associated with the cluster. This change is * asynchronously applied as soon as possible. */ public List vpcSecurityGroupIds() { return vpcSecurityGroupIds; } /** *

    * The new password for the cluster master user. This change is asynchronously applied as soon as possible. Between * the time of the request and the completion of the request, the MasterUserPassword element exists in * the PendingModifiedValues element of the operation response. *

    * *

    * Operations never return the password, so this operation provides a way to regain access to the master user * account for a cluster if the password is lost. *

    *
    *

    * Default: Uses existing setting. *

    *

    * Constraints: *

    *
      *
    • *

      * Must be between 8 and 64 characters in length. *

      *
    • *
    • *

      * Must contain at least one uppercase letter. *

      *
    • *
    • *

      * Must contain at least one lowercase letter. *

      *
    • *
    • *

      * Must contain one number. *

      *
    • *
    • *

      * Can be any printable ASCII character (ASCII code 33 to 126) except ' (single quote), " (double quote), \, /, @, * or space. *

      *
    • *
    * * @return The new password for the cluster master user. This change is asynchronously applied as soon as possible. * Between the time of the request and the completion of the request, the MasterUserPassword * element exists in the PendingModifiedValues element of the operation response.

    *

    * Operations never return the password, so this operation provides a way to regain access to the master * user account for a cluster if the password is lost. *

    *
    *

    * Default: Uses existing setting. *

    *

    * Constraints: *

    *
      *
    • *

      * Must be between 8 and 64 characters in length. *

      *
    • *
    • *

      * Must contain at least one uppercase letter. *

      *
    • *
    • *

      * Must contain at least one lowercase letter. *

      *
    • *
    • *

      * Must contain one number. *

      *
    • *
    • *

      * Can be any printable ASCII character (ASCII code 33 to 126) except ' (single quote), " (double quote), \, * /, @, or space. *

      *
    • */ public String masterUserPassword() { return masterUserPassword; } /** *

      * The name of the cluster parameter group to apply to this cluster. This change is applied only after the cluster * is rebooted. To reboot a cluster use RebootCluster. *

      *

      * Default: Uses existing setting. *

      *

      * Constraints: The cluster parameter group must be in the same parameter group family that matches the cluster * version. *

      * * @return The name of the cluster parameter group to apply to this cluster. This change is applied only after the * cluster is rebooted. To reboot a cluster use RebootCluster.

      *

      * Default: Uses existing setting. *

      *

      * Constraints: The cluster parameter group must be in the same parameter group family that matches the * cluster version. */ public String clusterParameterGroupName() { return clusterParameterGroupName; } /** *

      * The number of days that automated snapshots are retained. If the value is 0, automated snapshots are disabled. * Even if automated snapshots are disabled, you can still create manual snapshots when you want with * CreateClusterSnapshot. *

      *

      * If you decrease the automated snapshot retention period from its current value, existing automated snapshots that * fall outside of the new retention period will be immediately deleted. *

      *

      * Default: Uses existing setting. *

      *

      * Constraints: Must be a value from 0 to 35. *

      * * @return The number of days that automated snapshots are retained. If the value is 0, automated snapshots are * disabled. Even if automated snapshots are disabled, you can still create manual snapshots when you want * with CreateClusterSnapshot.

      *

      * If you decrease the automated snapshot retention period from its current value, existing automated * snapshots that fall outside of the new retention period will be immediately deleted. *

      *

      * Default: Uses existing setting. *

      *

      * Constraints: Must be a value from 0 to 35. */ public Integer automatedSnapshotRetentionPeriod() { return automatedSnapshotRetentionPeriod; } /** *

      * The default for number of days that a newly created manual snapshot is retained. If the value is -1, the manual * snapshot is retained indefinitely. This value doesn't retroactively change the retention periods of existing * manual snapshots. *

      *

      * The value must be either -1 or an integer between 1 and 3,653. *

      *

      * The default value is -1. *

      * * @return The default for number of days that a newly created manual snapshot is retained. If the value is -1, the * manual snapshot is retained indefinitely. This value doesn't retroactively change the retention periods * of existing manual snapshots.

      *

      * The value must be either -1 or an integer between 1 and 3,653. *

      *

      * The default value is -1. */ public Integer manualSnapshotRetentionPeriod() { return manualSnapshotRetentionPeriod; } /** *

      * The weekly time range (in UTC) during which system maintenance can occur, if necessary. If system maintenance is * necessary during the window, it may result in an outage. *

      *

      * This maintenance window change is made immediately. If the new maintenance window indicates the current time, * there must be at least 120 minutes between the current time and end of the window in order to ensure that pending * changes are applied. *

      *

      * Default: Uses existing setting. *

      *

      * Format: ddd:hh24:mi-ddd:hh24:mi, for example wed:07:30-wed:08:00. *

      *

      * Valid Days: Mon | Tue | Wed | Thu | Fri | Sat | Sun *

      *

      * Constraints: Must be at least 30 minutes. *

      * * @return The weekly time range (in UTC) during which system maintenance can occur, if necessary. If system * maintenance is necessary during the window, it may result in an outage.

      *

      * This maintenance window change is made immediately. If the new maintenance window indicates the current * time, there must be at least 120 minutes between the current time and end of the window in order to * ensure that pending changes are applied. *

      *

      * Default: Uses existing setting. *

      *

      * Format: ddd:hh24:mi-ddd:hh24:mi, for example wed:07:30-wed:08:00. *

      *

      * Valid Days: Mon | Tue | Wed | Thu | Fri | Sat | Sun *

      *

      * Constraints: Must be at least 30 minutes. */ public String preferredMaintenanceWindow() { return preferredMaintenanceWindow; } /** *

      * The new version number of the Amazon Redshift engine to upgrade to. *

      *

      * For major version upgrades, if a non-default cluster parameter group is currently in use, a new cluster parameter * group in the cluster parameter group family for the new version must be specified. The new cluster parameter * group can be the default for that cluster parameter group family. For more information about parameters and * parameter groups, go to Amazon Redshift * Parameter Groups in the Amazon Redshift Cluster Management Guide. *

      *

      * Example: 1.0 *

      * * @return The new version number of the Amazon Redshift engine to upgrade to.

      *

      * For major version upgrades, if a non-default cluster parameter group is currently in use, a new cluster * parameter group in the cluster parameter group family for the new version must be specified. The new * cluster parameter group can be the default for that cluster parameter group family. For more information * about parameters and parameter groups, go to Amazon * Redshift Parameter Groups in the Amazon Redshift Cluster Management Guide. *

      *

      * Example: 1.0 */ public String clusterVersion() { return clusterVersion; } /** *

      * If true, major version upgrades will be applied automatically to the cluster during the maintenance * window. *

      *

      * Default: false *

      * * @return If true, major version upgrades will be applied automatically to the cluster during the * maintenance window.

      *

      * Default: false */ public Boolean allowVersionUpgrade() { return allowVersionUpgrade; } /** *

      * Specifies the name of the HSM client certificate the Amazon Redshift cluster uses to retrieve the data encryption * keys stored in an HSM. *

      * * @return Specifies the name of the HSM client certificate the Amazon Redshift cluster uses to retrieve the data * encryption keys stored in an HSM. */ public String hsmClientCertificateIdentifier() { return hsmClientCertificateIdentifier; } /** *

      * Specifies the name of the HSM configuration that contains the information the Amazon Redshift cluster can use to * retrieve and store keys in an HSM. *

      * * @return Specifies the name of the HSM configuration that contains the information the Amazon Redshift cluster can * use to retrieve and store keys in an HSM. */ public String hsmConfigurationIdentifier() { return hsmConfigurationIdentifier; } /** *

      * The new identifier for the cluster. *

      *

      * Constraints: *

      *
        *
      • *

        * Must contain from 1 to 63 alphanumeric characters or hyphens. *

        *
      • *
      • *

        * Alphabetic characters must be lowercase. *

        *
      • *
      • *

        * First character must be a letter. *

        *
      • *
      • *

        * Cannot end with a hyphen or contain two consecutive hyphens. *

        *
      • *
      • *

        * Must be unique for all clusters within an AWS account. *

        *
      • *
      *

      * Example: examplecluster *

      * * @return The new identifier for the cluster.

      *

      * Constraints: *

      *
        *
      • *

        * Must contain from 1 to 63 alphanumeric characters or hyphens. *

        *
      • *
      • *

        * Alphabetic characters must be lowercase. *

        *
      • *
      • *

        * First character must be a letter. *

        *
      • *
      • *

        * Cannot end with a hyphen or contain two consecutive hyphens. *

        *
      • *
      • *

        * Must be unique for all clusters within an AWS account. *

        *
      • *
      *

      * Example: examplecluster */ public String newClusterIdentifier() { return newClusterIdentifier; } /** *

      * If true, the cluster can be accessed from a public network. Only clusters in VPCs can be set to be * publicly available. *

      * * @return If true, the cluster can be accessed from a public network. Only clusters in VPCs can be set * to be publicly available. */ public Boolean publiclyAccessible() { return publiclyAccessible; } /** *

      * The Elastic IP (EIP) address for the cluster. *

      *

      * Constraints: The cluster must be provisioned in EC2-VPC and publicly-accessible through an Internet gateway. For * more information about provisioning clusters in EC2-VPC, go to Supported * Platforms to Launch Your Cluster in the Amazon Redshift Cluster Management Guide. *

      * * @return The Elastic IP (EIP) address for the cluster.

      *

      * Constraints: The cluster must be provisioned in EC2-VPC and publicly-accessible through an Internet * gateway. For more information about provisioning clusters in EC2-VPC, go to Supported Platforms to Launch Your Cluster in the Amazon Redshift Cluster Management Guide. */ public String elasticIp() { return elasticIp; } /** *

      * An option that specifies whether to create the cluster with enhanced VPC routing enabled. To create a cluster * that uses enhanced VPC routing, the cluster must be in a VPC. For more information, see Enhanced VPC Routing in the * Amazon Redshift Cluster Management Guide. *

      *

      * If this option is true, enhanced VPC routing is enabled. *

      *

      * Default: false *

      * * @return An option that specifies whether to create the cluster with enhanced VPC routing enabled. To create a * cluster that uses enhanced VPC routing, the cluster must be in a VPC. For more information, see Enhanced VPC * Routing in the Amazon Redshift Cluster Management Guide.

      *

      * If this option is true, enhanced VPC routing is enabled. *

      *

      * Default: false */ public Boolean enhancedVpcRouting() { return enhancedVpcRouting; } /** *

      * The name for the maintenance track that you want to assign for the cluster. This name change is asynchronous. The * new track name stays in the PendingModifiedValues for the cluster until the next maintenance window. * When the maintenance track changes, the cluster is switched to the latest cluster release available for the * maintenance track. At this point, the maintenance track name is applied. *

      * * @return The name for the maintenance track that you want to assign for the cluster. This name change is * asynchronous. The new track name stays in the PendingModifiedValues for the cluster until * the next maintenance window. When the maintenance track changes, the cluster is switched to the latest * cluster release available for the maintenance track. At this point, the maintenance track name is * applied. */ public String maintenanceTrackName() { return maintenanceTrackName; } /** *

      * Indicates whether the cluster is encrypted. If the cluster is encrypted and you provide a value for the * KmsKeyId parameter, we will encrypt the cluster with the provided KmsKeyId. If you * don't provide a KmsKeyId, we will encrypt with the default key. In the China region we will use * legacy encryption if you specify that the cluster is encrypted. *

      * * @return Indicates whether the cluster is encrypted. If the cluster is encrypted and you provide a value for the * KmsKeyId parameter, we will encrypt the cluster with the provided KmsKeyId. If * you don't provide a KmsKeyId, we will encrypt with the default key. In the China region we * will use legacy encryption if you specify that the cluster is encrypted. */ public Boolean encrypted() { return encrypted; } /** *

      * The AWS Key Management Service (KMS) key ID of the encryption key that you want to use to encrypt data in the * cluster. *

      * * @return The AWS Key Management Service (KMS) key ID of the encryption key that you want to use to encrypt data in * the cluster. */ public String kmsKeyId() { return kmsKeyId; } @Override public Builder toBuilder() { return new BuilderImpl(this); } public static Builder builder() { return new BuilderImpl(); } public static Class serializableBuilderClass() { return BuilderImpl.class; } @Override public int hashCode() { int hashCode = 1; hashCode = 31 * hashCode + Objects.hashCode(clusterIdentifier()); hashCode = 31 * hashCode + Objects.hashCode(clusterType()); hashCode = 31 * hashCode + Objects.hashCode(nodeType()); hashCode = 31 * hashCode + Objects.hashCode(numberOfNodes()); hashCode = 31 * hashCode + Objects.hashCode(clusterSecurityGroups()); hashCode = 31 * hashCode + Objects.hashCode(vpcSecurityGroupIds()); hashCode = 31 * hashCode + Objects.hashCode(masterUserPassword()); hashCode = 31 * hashCode + Objects.hashCode(clusterParameterGroupName()); hashCode = 31 * hashCode + Objects.hashCode(automatedSnapshotRetentionPeriod()); hashCode = 31 * hashCode + Objects.hashCode(manualSnapshotRetentionPeriod()); hashCode = 31 * hashCode + Objects.hashCode(preferredMaintenanceWindow()); hashCode = 31 * hashCode + Objects.hashCode(clusterVersion()); hashCode = 31 * hashCode + Objects.hashCode(allowVersionUpgrade()); hashCode = 31 * hashCode + Objects.hashCode(hsmClientCertificateIdentifier()); hashCode = 31 * hashCode + Objects.hashCode(hsmConfigurationIdentifier()); hashCode = 31 * hashCode + Objects.hashCode(newClusterIdentifier()); hashCode = 31 * hashCode + Objects.hashCode(publiclyAccessible()); hashCode = 31 * hashCode + Objects.hashCode(elasticIp()); hashCode = 31 * hashCode + Objects.hashCode(enhancedVpcRouting()); hashCode = 31 * hashCode + Objects.hashCode(maintenanceTrackName()); hashCode = 31 * hashCode + Objects.hashCode(encrypted()); hashCode = 31 * hashCode + Objects.hashCode(kmsKeyId()); return hashCode; } @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (!(obj instanceof ModifyClusterRequest)) { return false; } ModifyClusterRequest other = (ModifyClusterRequest) obj; return Objects.equals(clusterIdentifier(), other.clusterIdentifier()) && Objects.equals(clusterType(), other.clusterType()) && Objects.equals(nodeType(), other.nodeType()) && Objects.equals(numberOfNodes(), other.numberOfNodes()) && Objects.equals(clusterSecurityGroups(), other.clusterSecurityGroups()) && Objects.equals(vpcSecurityGroupIds(), other.vpcSecurityGroupIds()) && Objects.equals(masterUserPassword(), other.masterUserPassword()) && Objects.equals(clusterParameterGroupName(), other.clusterParameterGroupName()) && Objects.equals(automatedSnapshotRetentionPeriod(), other.automatedSnapshotRetentionPeriod()) && Objects.equals(manualSnapshotRetentionPeriod(), other.manualSnapshotRetentionPeriod()) && Objects.equals(preferredMaintenanceWindow(), other.preferredMaintenanceWindow()) && Objects.equals(clusterVersion(), other.clusterVersion()) && Objects.equals(allowVersionUpgrade(), other.allowVersionUpgrade()) && Objects.equals(hsmClientCertificateIdentifier(), other.hsmClientCertificateIdentifier()) && Objects.equals(hsmConfigurationIdentifier(), other.hsmConfigurationIdentifier()) && Objects.equals(newClusterIdentifier(), other.newClusterIdentifier()) && Objects.equals(publiclyAccessible(), other.publiclyAccessible()) && Objects.equals(elasticIp(), other.elasticIp()) && Objects.equals(enhancedVpcRouting(), other.enhancedVpcRouting()) && Objects.equals(maintenanceTrackName(), other.maintenanceTrackName()) && Objects.equals(encrypted(), other.encrypted()) && Objects.equals(kmsKeyId(), other.kmsKeyId()); } /** * 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. */ @Override public String toString() { return ToString.builder("ModifyClusterRequest").add("ClusterIdentifier", clusterIdentifier()) .add("ClusterType", clusterType()).add("NodeType", nodeType()).add("NumberOfNodes", numberOfNodes()) .add("ClusterSecurityGroups", clusterSecurityGroups()).add("VpcSecurityGroupIds", vpcSecurityGroupIds()) .add("MasterUserPassword", masterUserPassword()).add("ClusterParameterGroupName", clusterParameterGroupName()) .add("AutomatedSnapshotRetentionPeriod", automatedSnapshotRetentionPeriod()) .add("ManualSnapshotRetentionPeriod", manualSnapshotRetentionPeriod()) .add("PreferredMaintenanceWindow", preferredMaintenanceWindow()).add("ClusterVersion", clusterVersion()) .add("AllowVersionUpgrade", allowVersionUpgrade()) .add("HsmClientCertificateIdentifier", hsmClientCertificateIdentifier()) .add("HsmConfigurationIdentifier", hsmConfigurationIdentifier()) .add("NewClusterIdentifier", newClusterIdentifier()).add("PubliclyAccessible", publiclyAccessible()) .add("ElasticIp", elasticIp()).add("EnhancedVpcRouting", enhancedVpcRouting()) .add("MaintenanceTrackName", maintenanceTrackName()).add("Encrypted", encrypted()).add("KmsKeyId", kmsKeyId()) .build(); } public Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "ClusterIdentifier": return Optional.ofNullable(clazz.cast(clusterIdentifier())); case "ClusterType": return Optional.ofNullable(clazz.cast(clusterType())); case "NodeType": return Optional.ofNullable(clazz.cast(nodeType())); case "NumberOfNodes": return Optional.ofNullable(clazz.cast(numberOfNodes())); case "ClusterSecurityGroups": return Optional.ofNullable(clazz.cast(clusterSecurityGroups())); case "VpcSecurityGroupIds": return Optional.ofNullable(clazz.cast(vpcSecurityGroupIds())); case "MasterUserPassword": return Optional.ofNullable(clazz.cast(masterUserPassword())); case "ClusterParameterGroupName": return Optional.ofNullable(clazz.cast(clusterParameterGroupName())); case "AutomatedSnapshotRetentionPeriod": return Optional.ofNullable(clazz.cast(automatedSnapshotRetentionPeriod())); case "ManualSnapshotRetentionPeriod": return Optional.ofNullable(clazz.cast(manualSnapshotRetentionPeriod())); case "PreferredMaintenanceWindow": return Optional.ofNullable(clazz.cast(preferredMaintenanceWindow())); case "ClusterVersion": return Optional.ofNullable(clazz.cast(clusterVersion())); case "AllowVersionUpgrade": return Optional.ofNullable(clazz.cast(allowVersionUpgrade())); case "HsmClientCertificateIdentifier": return Optional.ofNullable(clazz.cast(hsmClientCertificateIdentifier())); case "HsmConfigurationIdentifier": return Optional.ofNullable(clazz.cast(hsmConfigurationIdentifier())); case "NewClusterIdentifier": return Optional.ofNullable(clazz.cast(newClusterIdentifier())); case "PubliclyAccessible": return Optional.ofNullable(clazz.cast(publiclyAccessible())); case "ElasticIp": return Optional.ofNullable(clazz.cast(elasticIp())); case "EnhancedVpcRouting": return Optional.ofNullable(clazz.cast(enhancedVpcRouting())); case "MaintenanceTrackName": return Optional.ofNullable(clazz.cast(maintenanceTrackName())); case "Encrypted": return Optional.ofNullable(clazz.cast(encrypted())); case "KmsKeyId": return Optional.ofNullable(clazz.cast(kmsKeyId())); default: return Optional.empty(); } } @Override public List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((ModifyClusterRequest) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends RedshiftRequest.Builder, SdkPojo, CopyableBuilder { /** *

      * The unique identifier of the cluster to be modified. *

      *

      * Example: examplecluster *

      * * @param clusterIdentifier * The unique identifier of the cluster to be modified.

      *

      * Example: examplecluster * @return Returns a reference to this object so that method calls can be chained together. */ Builder clusterIdentifier(String clusterIdentifier); /** *

      * The new cluster type. *

      *

      * When you submit your cluster resize request, your existing cluster goes into a read-only mode. After Amazon * Redshift provisions a new cluster based on your resize requirements, there will be outage for a period while * the old cluster is deleted and your connection is switched to the new cluster. You can use * DescribeResize to track the progress of the resize request. *

      *

      * Valid Values: multi-node | single-node *

      * * @param clusterType * The new cluster type.

      *

      * When you submit your cluster resize request, your existing cluster goes into a read-only mode. After * Amazon Redshift provisions a new cluster based on your resize requirements, there will be outage for a * period while the old cluster is deleted and your connection is switched to the new cluster. You can * use DescribeResize to track the progress of the resize request. *

      *

      * Valid Values: multi-node | single-node * @return Returns a reference to this object so that method calls can be chained together. */ Builder clusterType(String clusterType); /** *

      * The new node type of the cluster. If you specify a new node type, you must also specify the number of nodes * parameter. *

      *

      * When you submit your request to resize a cluster, Amazon Redshift sets access permissions for the cluster to * read-only. After Amazon Redshift provisions a new cluster according to your resize requirements, there will * be a temporary outage while the old cluster is deleted and your connection is switched to the new cluster. * When the new connection is complete, the original access permissions for the cluster are restored. You can * use DescribeResize to track the progress of the resize request. *

      *

      * Valid Values: ds2.xlarge | ds2.8xlarge | dc1.large | * dc1.8xlarge | dc2.large | dc2.8xlarge *

      * * @param nodeType * The new node type of the cluster. If you specify a new node type, you must also specify the number of * nodes parameter.

      *

      * When you submit your request to resize a cluster, Amazon Redshift sets access permissions for the * cluster to read-only. After Amazon Redshift provisions a new cluster according to your resize * requirements, there will be a temporary outage while the old cluster is deleted and your connection is * switched to the new cluster. When the new connection is complete, the original access permissions for * the cluster are restored. You can use DescribeResize to track the progress of the resize * request. *

      *

      * Valid Values: ds2.xlarge | ds2.8xlarge | dc1.large | * dc1.8xlarge | dc2.large | dc2.8xlarge * @return Returns a reference to this object so that method calls can be chained together. */ Builder nodeType(String nodeType); /** *

      * The new number of nodes of the cluster. If you specify a new number of nodes, you must also specify the node * type parameter. *

      *

      * When you submit your request to resize a cluster, Amazon Redshift sets access permissions for the cluster to * read-only. After Amazon Redshift provisions a new cluster according to your resize requirements, there will * be a temporary outage while the old cluster is deleted and your connection is switched to the new cluster. * When the new connection is complete, the original access permissions for the cluster are restored. You can * use DescribeResize to track the progress of the resize request. *

      *

      * Valid Values: Integer greater than 0. *

      * * @param numberOfNodes * The new number of nodes of the cluster. If you specify a new number of nodes, you must also specify * the node type parameter.

      *

      * When you submit your request to resize a cluster, Amazon Redshift sets access permissions for the * cluster to read-only. After Amazon Redshift provisions a new cluster according to your resize * requirements, there will be a temporary outage while the old cluster is deleted and your connection is * switched to the new cluster. When the new connection is complete, the original access permissions for * the cluster are restored. You can use DescribeResize to track the progress of the resize * request. *

      *

      * Valid Values: Integer greater than 0. * @return Returns a reference to this object so that method calls can be chained together. */ Builder numberOfNodes(Integer numberOfNodes); /** *

      * A list of cluster security groups to be authorized on this cluster. This change is asynchronously applied as * soon as possible. *

      *

      * Security groups currently associated with the cluster, and not in the list of groups to apply, will be * revoked from the cluster. *

      *

      * Constraints: *

      *
        *
      • *

        * Must be 1 to 255 alphanumeric characters or hyphens *

        *
      • *
      • *

        * First character must be a letter *

        *
      • *
      • *

        * Cannot end with a hyphen or contain two consecutive hyphens *

        *
      • *
      * * @param clusterSecurityGroups * A list of cluster security groups to be authorized on this cluster. This change is asynchronously * applied as soon as possible.

      *

      * Security groups currently associated with the cluster, and not in the list of groups to apply, will be * revoked from the cluster. *

      *

      * Constraints: *

      *
        *
      • *

        * Must be 1 to 255 alphanumeric characters or hyphens *

        *
      • *
      • *

        * First character must be a letter *

        *
      • *
      • *

        * Cannot end with a hyphen or contain two consecutive hyphens *

        *
      • * @return Returns a reference to this object so that method calls can be chained together. */ Builder clusterSecurityGroups(Collection clusterSecurityGroups); /** *

        * A list of cluster security groups to be authorized on this cluster. This change is asynchronously applied as * soon as possible. *

        *

        * Security groups currently associated with the cluster, and not in the list of groups to apply, will be * revoked from the cluster. *

        *

        * Constraints: *

        *
          *
        • *

          * Must be 1 to 255 alphanumeric characters or hyphens *

          *
        • *
        • *

          * First character must be a letter *

          *
        • *
        • *

          * Cannot end with a hyphen or contain two consecutive hyphens *

          *
        • *
        * * @param clusterSecurityGroups * A list of cluster security groups to be authorized on this cluster. This change is asynchronously * applied as soon as possible.

        *

        * Security groups currently associated with the cluster, and not in the list of groups to apply, will be * revoked from the cluster. *

        *

        * Constraints: *

        *
          *
        • *

          * Must be 1 to 255 alphanumeric characters or hyphens *

          *
        • *
        • *

          * First character must be a letter *

          *
        • *
        • *

          * Cannot end with a hyphen or contain two consecutive hyphens *

          *
        • * @return Returns a reference to this object so that method calls can be chained together. */ Builder clusterSecurityGroups(String... clusterSecurityGroups); /** *

          * A list of virtual private cloud (VPC) security groups to be associated with the cluster. This change is * asynchronously applied as soon as possible. *

          * * @param vpcSecurityGroupIds * A list of virtual private cloud (VPC) security groups to be associated with the cluster. This change * is asynchronously applied as soon as possible. * @return Returns a reference to this object so that method calls can be chained together. */ Builder vpcSecurityGroupIds(Collection vpcSecurityGroupIds); /** *

          * A list of virtual private cloud (VPC) security groups to be associated with the cluster. This change is * asynchronously applied as soon as possible. *

          * * @param vpcSecurityGroupIds * A list of virtual private cloud (VPC) security groups to be associated with the cluster. This change * is asynchronously applied as soon as possible. * @return Returns a reference to this object so that method calls can be chained together. */ Builder vpcSecurityGroupIds(String... vpcSecurityGroupIds); /** *

          * The new password for the cluster master user. This change is asynchronously applied as soon as possible. * Between the time of the request and the completion of the request, the MasterUserPassword * element exists in the PendingModifiedValues element of the operation response. *

          * *

          * Operations never return the password, so this operation provides a way to regain access to the master user * account for a cluster if the password is lost. *

          *
          *

          * Default: Uses existing setting. *

          *

          * Constraints: *

          *
            *
          • *

            * Must be between 8 and 64 characters in length. *

            *
          • *
          • *

            * Must contain at least one uppercase letter. *

            *
          • *
          • *

            * Must contain at least one lowercase letter. *

            *
          • *
          • *

            * Must contain one number. *

            *
          • *
          • *

            * Can be any printable ASCII character (ASCII code 33 to 126) except ' (single quote), " (double quote), \, /, @, * or space. *

            *
          • *
          * * @param masterUserPassword * The new password for the cluster master user. This change is asynchronously applied as soon as * possible. Between the time of the request and the completion of the request, the * MasterUserPassword element exists in the PendingModifiedValues element of * the operation response.

          *

          * Operations never return the password, so this operation provides a way to regain access to the master * user account for a cluster if the password is lost. *

          *
          *

          * Default: Uses existing setting. *

          *

          * Constraints: *

          *
            *
          • *

            * Must be between 8 and 64 characters in length. *

            *
          • *
          • *

            * Must contain at least one uppercase letter. *

            *
          • *
          • *

            * Must contain at least one lowercase letter. *

            *
          • *
          • *

            * Must contain one number. *

            *
          • *
          • *

            * Can be any printable ASCII character (ASCII code 33 to 126) except ' (single quote), " (double quote), * \, /, @, or space. *

            *
          • * @return Returns a reference to this object so that method calls can be chained together. */ Builder masterUserPassword(String masterUserPassword); /** *

            * The name of the cluster parameter group to apply to this cluster. This change is applied only after the * cluster is rebooted. To reboot a cluster use RebootCluster. *

            *

            * Default: Uses existing setting. *

            *

            * Constraints: The cluster parameter group must be in the same parameter group family that matches the cluster * version. *

            * * @param clusterParameterGroupName * The name of the cluster parameter group to apply to this cluster. This change is applied only after * the cluster is rebooted. To reboot a cluster use RebootCluster.

            *

            * Default: Uses existing setting. *

            *

            * Constraints: The cluster parameter group must be in the same parameter group family that matches the * cluster version. * @return Returns a reference to this object so that method calls can be chained together. */ Builder clusterParameterGroupName(String clusterParameterGroupName); /** *

            * The number of days that automated snapshots are retained. If the value is 0, automated snapshots are * disabled. Even if automated snapshots are disabled, you can still create manual snapshots when you want with * CreateClusterSnapshot. *

            *

            * If you decrease the automated snapshot retention period from its current value, existing automated snapshots * that fall outside of the new retention period will be immediately deleted. *

            *

            * Default: Uses existing setting. *

            *

            * Constraints: Must be a value from 0 to 35. *

            * * @param automatedSnapshotRetentionPeriod * The number of days that automated snapshots are retained. If the value is 0, automated snapshots are * disabled. Even if automated snapshots are disabled, you can still create manual snapshots when you * want with CreateClusterSnapshot.

            *

            * If you decrease the automated snapshot retention period from its current value, existing automated * snapshots that fall outside of the new retention period will be immediately deleted. *

            *

            * Default: Uses existing setting. *

            *

            * Constraints: Must be a value from 0 to 35. * @return Returns a reference to this object so that method calls can be chained together. */ Builder automatedSnapshotRetentionPeriod(Integer automatedSnapshotRetentionPeriod); /** *

            * The default for number of days that a newly created manual snapshot is retained. If the value is -1, the * manual snapshot is retained indefinitely. This value doesn't retroactively change the retention periods of * existing manual snapshots. *

            *

            * The value must be either -1 or an integer between 1 and 3,653. *

            *

            * The default value is -1. *

            * * @param manualSnapshotRetentionPeriod * The default for number of days that a newly created manual snapshot is retained. If the value is -1, * the manual snapshot is retained indefinitely. This value doesn't retroactively change the retention * periods of existing manual snapshots.

            *

            * The value must be either -1 or an integer between 1 and 3,653. *

            *

            * The default value is -1. * @return Returns a reference to this object so that method calls can be chained together. */ Builder manualSnapshotRetentionPeriod(Integer manualSnapshotRetentionPeriod); /** *

            * The weekly time range (in UTC) during which system maintenance can occur, if necessary. If system maintenance * is necessary during the window, it may result in an outage. *

            *

            * This maintenance window change is made immediately. If the new maintenance window indicates the current time, * there must be at least 120 minutes between the current time and end of the window in order to ensure that * pending changes are applied. *

            *

            * Default: Uses existing setting. *

            *

            * Format: ddd:hh24:mi-ddd:hh24:mi, for example wed:07:30-wed:08:00. *

            *

            * Valid Days: Mon | Tue | Wed | Thu | Fri | Sat | Sun *

            *

            * Constraints: Must be at least 30 minutes. *

            * * @param preferredMaintenanceWindow * The weekly time range (in UTC) during which system maintenance can occur, if necessary. If system * maintenance is necessary during the window, it may result in an outage.

            *

            * This maintenance window change is made immediately. If the new maintenance window indicates the * current time, there must be at least 120 minutes between the current time and end of the window in * order to ensure that pending changes are applied. *

            *

            * Default: Uses existing setting. *

            *

            * Format: ddd:hh24:mi-ddd:hh24:mi, for example wed:07:30-wed:08:00. *

            *

            * Valid Days: Mon | Tue | Wed | Thu | Fri | Sat | Sun *

            *

            * Constraints: Must be at least 30 minutes. * @return Returns a reference to this object so that method calls can be chained together. */ Builder preferredMaintenanceWindow(String preferredMaintenanceWindow); /** *

            * The new version number of the Amazon Redshift engine to upgrade to. *

            *

            * For major version upgrades, if a non-default cluster parameter group is currently in use, a new cluster * parameter group in the cluster parameter group family for the new version must be specified. The new cluster * parameter group can be the default for that cluster parameter group family. For more information about * parameters and parameter groups, go to Amazon Redshift * Parameter Groups in the Amazon Redshift Cluster Management Guide. *

            *

            * Example: 1.0 *

            * * @param clusterVersion * The new version number of the Amazon Redshift engine to upgrade to.

            *

            * For major version upgrades, if a non-default cluster parameter group is currently in use, a new * cluster parameter group in the cluster parameter group family for the new version must be specified. * The new cluster parameter group can be the default for that cluster parameter group family. For more * information about parameters and parameter groups, go to Amazon * Redshift Parameter Groups in the Amazon Redshift Cluster Management Guide. *

            *

            * Example: 1.0 * @return Returns a reference to this object so that method calls can be chained together. */ Builder clusterVersion(String clusterVersion); /** *

            * If true, major version upgrades will be applied automatically to the cluster during the * maintenance window. *

            *

            * Default: false *

            * * @param allowVersionUpgrade * If true, major version upgrades will be applied automatically to the cluster during the * maintenance window.

            *

            * Default: false * @return Returns a reference to this object so that method calls can be chained together. */ Builder allowVersionUpgrade(Boolean allowVersionUpgrade); /** *

            * Specifies the name of the HSM client certificate the Amazon Redshift cluster uses to retrieve the data * encryption keys stored in an HSM. *

            * * @param hsmClientCertificateIdentifier * Specifies the name of the HSM client certificate the Amazon Redshift cluster uses to retrieve the data * encryption keys stored in an HSM. * @return Returns a reference to this object so that method calls can be chained together. */ Builder hsmClientCertificateIdentifier(String hsmClientCertificateIdentifier); /** *

            * Specifies the name of the HSM configuration that contains the information the Amazon Redshift cluster can use * to retrieve and store keys in an HSM. *

            * * @param hsmConfigurationIdentifier * Specifies the name of the HSM configuration that contains the information the Amazon Redshift cluster * can use to retrieve and store keys in an HSM. * @return Returns a reference to this object so that method calls can be chained together. */ Builder hsmConfigurationIdentifier(String hsmConfigurationIdentifier); /** *

            * The new identifier for the cluster. *

            *

            * Constraints: *

            *
              *
            • *

              * Must contain from 1 to 63 alphanumeric characters or hyphens. *

              *
            • *
            • *

              * Alphabetic characters must be lowercase. *

              *
            • *
            • *

              * First character must be a letter. *

              *
            • *
            • *

              * Cannot end with a hyphen or contain two consecutive hyphens. *

              *
            • *
            • *

              * Must be unique for all clusters within an AWS account. *

              *
            • *
            *

            * Example: examplecluster *

            * * @param newClusterIdentifier * The new identifier for the cluster.

            *

            * Constraints: *

            *
              *
            • *

              * Must contain from 1 to 63 alphanumeric characters or hyphens. *

              *
            • *
            • *

              * Alphabetic characters must be lowercase. *

              *
            • *
            • *

              * First character must be a letter. *

              *
            • *
            • *

              * Cannot end with a hyphen or contain two consecutive hyphens. *

              *
            • *
            • *

              * Must be unique for all clusters within an AWS account. *

              *
            • *
            *

            * Example: examplecluster * @return Returns a reference to this object so that method calls can be chained together. */ Builder newClusterIdentifier(String newClusterIdentifier); /** *

            * If true, the cluster can be accessed from a public network. Only clusters in VPCs can be set to * be publicly available. *

            * * @param publiclyAccessible * If true, the cluster can be accessed from a public network. Only clusters in VPCs can be * set to be publicly available. * @return Returns a reference to this object so that method calls can be chained together. */ Builder publiclyAccessible(Boolean publiclyAccessible); /** *

            * The Elastic IP (EIP) address for the cluster. *

            *

            * Constraints: The cluster must be provisioned in EC2-VPC and publicly-accessible through an Internet gateway. * For more information about provisioning clusters in EC2-VPC, go to Supported Platforms to Launch Your Cluster in the Amazon Redshift Cluster Management Guide. *

            * * @param elasticIp * The Elastic IP (EIP) address for the cluster.

            *

            * Constraints: The cluster must be provisioned in EC2-VPC and publicly-accessible through an Internet * gateway. For more information about provisioning clusters in EC2-VPC, go to Supported Platforms to Launch Your Cluster in the Amazon Redshift Cluster Management Guide. * @return Returns a reference to this object so that method calls can be chained together. */ Builder elasticIp(String elasticIp); /** *

            * An option that specifies whether to create the cluster with enhanced VPC routing enabled. To create a cluster * that uses enhanced VPC routing, the cluster must be in a VPC. For more information, see Enhanced VPC Routing in * the Amazon Redshift Cluster Management Guide. *

            *

            * If this option is true, enhanced VPC routing is enabled. *

            *

            * Default: false *

            * * @param enhancedVpcRouting * An option that specifies whether to create the cluster with enhanced VPC routing enabled. To create a * cluster that uses enhanced VPC routing, the cluster must be in a VPC. For more information, see Enhanced VPC * Routing in the Amazon Redshift Cluster Management Guide.

            *

            * If this option is true, enhanced VPC routing is enabled. *

            *

            * Default: false * @return Returns a reference to this object so that method calls can be chained together. */ Builder enhancedVpcRouting(Boolean enhancedVpcRouting); /** *

            * The name for the maintenance track that you want to assign for the cluster. This name change is asynchronous. * The new track name stays in the PendingModifiedValues for the cluster until the next maintenance * window. When the maintenance track changes, the cluster is switched to the latest cluster release available * for the maintenance track. At this point, the maintenance track name is applied. *

            * * @param maintenanceTrackName * The name for the maintenance track that you want to assign for the cluster. This name change is * asynchronous. The new track name stays in the PendingModifiedValues for the cluster until * the next maintenance window. When the maintenance track changes, the cluster is switched to the latest * cluster release available for the maintenance track. At this point, the maintenance track name is * applied. * @return Returns a reference to this object so that method calls can be chained together. */ Builder maintenanceTrackName(String maintenanceTrackName); /** *

            * Indicates whether the cluster is encrypted. If the cluster is encrypted and you provide a value for the * KmsKeyId parameter, we will encrypt the cluster with the provided KmsKeyId. If you * don't provide a KmsKeyId, we will encrypt with the default key. In the China region we will use * legacy encryption if you specify that the cluster is encrypted. *

            * * @param encrypted * Indicates whether the cluster is encrypted. If the cluster is encrypted and you provide a value for * the KmsKeyId parameter, we will encrypt the cluster with the provided * KmsKeyId. If you don't provide a KmsKeyId, we will encrypt with the default * key. In the China region we will use legacy encryption if you specify that the cluster is encrypted. * @return Returns a reference to this object so that method calls can be chained together. */ Builder encrypted(Boolean encrypted); /** *

            * The AWS Key Management Service (KMS) key ID of the encryption key that you want to use to encrypt data in the * cluster. *

            * * @param kmsKeyId * The AWS Key Management Service (KMS) key ID of the encryption key that you want to use to encrypt data * in the cluster. * @return Returns a reference to this object so that method calls can be chained together. */ Builder kmsKeyId(String kmsKeyId); @Override Builder overrideConfiguration(AwsRequestOverrideConfiguration overrideConfiguration); @Override Builder overrideConfiguration(Consumer builderConsumer); } static final class BuilderImpl extends RedshiftRequest.BuilderImpl implements Builder { private String clusterIdentifier; private String clusterType; private String nodeType; private Integer numberOfNodes; private List clusterSecurityGroups = DefaultSdkAutoConstructList.getInstance(); private List vpcSecurityGroupIds = DefaultSdkAutoConstructList.getInstance(); private String masterUserPassword; private String clusterParameterGroupName; private Integer automatedSnapshotRetentionPeriod; private Integer manualSnapshotRetentionPeriod; private String preferredMaintenanceWindow; private String clusterVersion; private Boolean allowVersionUpgrade; private String hsmClientCertificateIdentifier; private String hsmConfigurationIdentifier; private String newClusterIdentifier; private Boolean publiclyAccessible; private String elasticIp; private Boolean enhancedVpcRouting; private String maintenanceTrackName; private Boolean encrypted; private String kmsKeyId; private BuilderImpl() { } private BuilderImpl(ModifyClusterRequest model) { super(model); clusterIdentifier(model.clusterIdentifier); clusterType(model.clusterType); nodeType(model.nodeType); numberOfNodes(model.numberOfNodes); clusterSecurityGroups(model.clusterSecurityGroups); vpcSecurityGroupIds(model.vpcSecurityGroupIds); masterUserPassword(model.masterUserPassword); clusterParameterGroupName(model.clusterParameterGroupName); automatedSnapshotRetentionPeriod(model.automatedSnapshotRetentionPeriod); manualSnapshotRetentionPeriod(model.manualSnapshotRetentionPeriod); preferredMaintenanceWindow(model.preferredMaintenanceWindow); clusterVersion(model.clusterVersion); allowVersionUpgrade(model.allowVersionUpgrade); hsmClientCertificateIdentifier(model.hsmClientCertificateIdentifier); hsmConfigurationIdentifier(model.hsmConfigurationIdentifier); newClusterIdentifier(model.newClusterIdentifier); publiclyAccessible(model.publiclyAccessible); elasticIp(model.elasticIp); enhancedVpcRouting(model.enhancedVpcRouting); maintenanceTrackName(model.maintenanceTrackName); encrypted(model.encrypted); kmsKeyId(model.kmsKeyId); } public final String getClusterIdentifier() { return clusterIdentifier; } @Override public final Builder clusterIdentifier(String clusterIdentifier) { this.clusterIdentifier = clusterIdentifier; return this; } public final void setClusterIdentifier(String clusterIdentifier) { this.clusterIdentifier = clusterIdentifier; } public final String getClusterType() { return clusterType; } @Override public final Builder clusterType(String clusterType) { this.clusterType = clusterType; return this; } public final void setClusterType(String clusterType) { this.clusterType = clusterType; } public final String getNodeType() { return nodeType; } @Override public final Builder nodeType(String nodeType) { this.nodeType = nodeType; return this; } public final void setNodeType(String nodeType) { this.nodeType = nodeType; } public final Integer getNumberOfNodes() { return numberOfNodes; } @Override public final Builder numberOfNodes(Integer numberOfNodes) { this.numberOfNodes = numberOfNodes; return this; } public final void setNumberOfNodes(Integer numberOfNodes) { this.numberOfNodes = numberOfNodes; } public final Collection getClusterSecurityGroups() { return clusterSecurityGroups; } @Override public final Builder clusterSecurityGroups(Collection clusterSecurityGroups) { this.clusterSecurityGroups = ClusterSecurityGroupNameListCopier.copy(clusterSecurityGroups); return this; } @Override @SafeVarargs public final Builder clusterSecurityGroups(String... clusterSecurityGroups) { clusterSecurityGroups(Arrays.asList(clusterSecurityGroups)); return this; } public final void setClusterSecurityGroups(Collection clusterSecurityGroups) { this.clusterSecurityGroups = ClusterSecurityGroupNameListCopier.copy(clusterSecurityGroups); } public final Collection getVpcSecurityGroupIds() { return vpcSecurityGroupIds; } @Override public final Builder vpcSecurityGroupIds(Collection vpcSecurityGroupIds) { this.vpcSecurityGroupIds = VpcSecurityGroupIdListCopier.copy(vpcSecurityGroupIds); return this; } @Override @SafeVarargs public final Builder vpcSecurityGroupIds(String... vpcSecurityGroupIds) { vpcSecurityGroupIds(Arrays.asList(vpcSecurityGroupIds)); return this; } public final void setVpcSecurityGroupIds(Collection vpcSecurityGroupIds) { this.vpcSecurityGroupIds = VpcSecurityGroupIdListCopier.copy(vpcSecurityGroupIds); } public final String getMasterUserPassword() { return masterUserPassword; } @Override public final Builder masterUserPassword(String masterUserPassword) { this.masterUserPassword = masterUserPassword; return this; } public final void setMasterUserPassword(String masterUserPassword) { this.masterUserPassword = masterUserPassword; } public final String getClusterParameterGroupName() { return clusterParameterGroupName; } @Override public final Builder clusterParameterGroupName(String clusterParameterGroupName) { this.clusterParameterGroupName = clusterParameterGroupName; return this; } public final void setClusterParameterGroupName(String clusterParameterGroupName) { this.clusterParameterGroupName = clusterParameterGroupName; } public final Integer getAutomatedSnapshotRetentionPeriod() { return automatedSnapshotRetentionPeriod; } @Override public final Builder automatedSnapshotRetentionPeriod(Integer automatedSnapshotRetentionPeriod) { this.automatedSnapshotRetentionPeriod = automatedSnapshotRetentionPeriod; return this; } public final void setAutomatedSnapshotRetentionPeriod(Integer automatedSnapshotRetentionPeriod) { this.automatedSnapshotRetentionPeriod = automatedSnapshotRetentionPeriod; } public final Integer getManualSnapshotRetentionPeriod() { return manualSnapshotRetentionPeriod; } @Override public final Builder manualSnapshotRetentionPeriod(Integer manualSnapshotRetentionPeriod) { this.manualSnapshotRetentionPeriod = manualSnapshotRetentionPeriod; return this; } public final void setManualSnapshotRetentionPeriod(Integer manualSnapshotRetentionPeriod) { this.manualSnapshotRetentionPeriod = manualSnapshotRetentionPeriod; } public final String getPreferredMaintenanceWindow() { return preferredMaintenanceWindow; } @Override public final Builder preferredMaintenanceWindow(String preferredMaintenanceWindow) { this.preferredMaintenanceWindow = preferredMaintenanceWindow; return this; } public final void setPreferredMaintenanceWindow(String preferredMaintenanceWindow) { this.preferredMaintenanceWindow = preferredMaintenanceWindow; } public final String getClusterVersion() { return clusterVersion; } @Override public final Builder clusterVersion(String clusterVersion) { this.clusterVersion = clusterVersion; return this; } public final void setClusterVersion(String clusterVersion) { this.clusterVersion = clusterVersion; } public final Boolean getAllowVersionUpgrade() { return allowVersionUpgrade; } @Override public final Builder allowVersionUpgrade(Boolean allowVersionUpgrade) { this.allowVersionUpgrade = allowVersionUpgrade; return this; } public final void setAllowVersionUpgrade(Boolean allowVersionUpgrade) { this.allowVersionUpgrade = allowVersionUpgrade; } public final String getHsmClientCertificateIdentifier() { return hsmClientCertificateIdentifier; } @Override public final Builder hsmClientCertificateIdentifier(String hsmClientCertificateIdentifier) { this.hsmClientCertificateIdentifier = hsmClientCertificateIdentifier; return this; } public final void setHsmClientCertificateIdentifier(String hsmClientCertificateIdentifier) { this.hsmClientCertificateIdentifier = hsmClientCertificateIdentifier; } public final String getHsmConfigurationIdentifier() { return hsmConfigurationIdentifier; } @Override public final Builder hsmConfigurationIdentifier(String hsmConfigurationIdentifier) { this.hsmConfigurationIdentifier = hsmConfigurationIdentifier; return this; } public final void setHsmConfigurationIdentifier(String hsmConfigurationIdentifier) { this.hsmConfigurationIdentifier = hsmConfigurationIdentifier; } public final String getNewClusterIdentifier() { return newClusterIdentifier; } @Override public final Builder newClusterIdentifier(String newClusterIdentifier) { this.newClusterIdentifier = newClusterIdentifier; return this; } public final void setNewClusterIdentifier(String newClusterIdentifier) { this.newClusterIdentifier = newClusterIdentifier; } public final Boolean getPubliclyAccessible() { return publiclyAccessible; } @Override public final Builder publiclyAccessible(Boolean publiclyAccessible) { this.publiclyAccessible = publiclyAccessible; return this; } public final void setPubliclyAccessible(Boolean publiclyAccessible) { this.publiclyAccessible = publiclyAccessible; } public final String getElasticIp() { return elasticIp; } @Override public final Builder elasticIp(String elasticIp) { this.elasticIp = elasticIp; return this; } public final void setElasticIp(String elasticIp) { this.elasticIp = elasticIp; } public final Boolean getEnhancedVpcRouting() { return enhancedVpcRouting; } @Override public final Builder enhancedVpcRouting(Boolean enhancedVpcRouting) { this.enhancedVpcRouting = enhancedVpcRouting; return this; } public final void setEnhancedVpcRouting(Boolean enhancedVpcRouting) { this.enhancedVpcRouting = enhancedVpcRouting; } public final String getMaintenanceTrackName() { return maintenanceTrackName; } @Override public final Builder maintenanceTrackName(String maintenanceTrackName) { this.maintenanceTrackName = maintenanceTrackName; return this; } public final void setMaintenanceTrackName(String maintenanceTrackName) { this.maintenanceTrackName = maintenanceTrackName; } public final Boolean getEncrypted() { return encrypted; } @Override public final Builder encrypted(Boolean encrypted) { this.encrypted = encrypted; return this; } public final void setEncrypted(Boolean encrypted) { this.encrypted = encrypted; } public final String getKmsKeyId() { return kmsKeyId; } @Override public final Builder kmsKeyId(String kmsKeyId) { this.kmsKeyId = kmsKeyId; return this; } public final void setKmsKeyId(String kmsKeyId) { this.kmsKeyId = kmsKeyId; } @Override public Builder overrideConfiguration(AwsRequestOverrideConfiguration overrideConfiguration) { super.overrideConfiguration(overrideConfiguration); return this; } @Override public Builder overrideConfiguration(Consumer builderConsumer) { super.overrideConfiguration(builderConsumer); return this; } @Override public ModifyClusterRequest build() { return new ModifyClusterRequest(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy