/*
 * Copyright 2018-2023 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.autoscalingplans.model;

import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;

/**
 * <p>
 * Describes a scaling instruction for a scalable resource in a scaling plan. Each scaling instruction applies to one
 * resource.
 * </p>
 * <p>
 * AWS Auto Scaling creates target tracking scaling policies based on the scaling instructions. Target tracking scaling
 * policies adjust the capacity of your scalable resource as required to maintain resource utilization at the target
 * value that you specified.
 * </p>
 * <p>
 * AWS Auto Scaling also configures predictive scaling for your Amazon EC2 Auto Scaling groups using a subset of
 * parameters, including the load metric, the scaling metric, the target value for the scaling metric, the predictive
 * scaling mode (forecast and scale or forecast only), and the desired behavior when the forecast capacity exceeds the
 * maximum capacity of the resource. With predictive scaling, AWS Auto Scaling generates forecasts with traffic
 * predictions for the two days ahead and schedules scaling actions that proactively add and remove resource capacity to
 * match the forecast.
 * </p>
 * <important>
 * <p>
 * We recommend waiting a minimum of 24 hours after creating an Auto Scaling group to configure predictive scaling. At
 * minimum, there must be 24 hours of historical data to generate a forecast. For more information, see <a
 * href="https://docs.aws.amazon.com/autoscaling/plans/userguide/gs-best-practices.html">Best Practices for AWS Auto
 * Scaling</a> in the <i>AWS Auto Scaling User Guide</i>.
 * </p>
 * </important>
 * 
 * @see <a href="http://docs.aws.amazon.com/goto/WebAPI/autoscaling-plans-2018-01-06/ScalingInstruction"
 *      target="_top">AWS API Documentation</a>
 */
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class ScalingInstruction implements Serializable, Cloneable, StructuredPojo {

    /**
     * <p>
     * The namespace of the AWS service.
     * </p>
     */
    private String serviceNamespace;
    /**
     * <p>
     * The ID of the resource. This string consists of the resource type and unique identifier.
     * </p>
     * <ul>
     * <li>
     * <p>
     * Auto Scaling group - The resource type is <code>autoScalingGroup</code> and the unique identifier is the name of
     * the Auto Scaling group. Example: <code>autoScalingGroup/my-asg</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * ECS service - The resource type is <code>service</code> and the unique identifier is the cluster name and service
     * name. Example: <code>service/default/sample-webapp</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * Spot Fleet request - The resource type is <code>spot-fleet-request</code> and the unique identifier is the Spot
     * Fleet request ID. Example: <code>spot-fleet-request/sfr-73fbd2ce-aa30-494c-8788-1cee4EXAMPLE</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * DynamoDB table - The resource type is <code>table</code> and the unique identifier is the resource ID. Example:
     * <code>table/my-table</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * DynamoDB global secondary index - The resource type is <code>index</code> and the unique identifier is the
     * resource ID. Example: <code>table/my-table/index/my-table-index</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * Aurora DB cluster - The resource type is <code>cluster</code> and the unique identifier is the cluster name.
     * Example: <code>cluster:my-db-cluster</code>.
     * </p>
     * </li>
     * </ul>
     */
    private String resourceId;
    /**
     * <p>
     * The scalable dimension associated with the resource.
     * </p>
     * <ul>
     * <li>
     * <p>
     * <code>autoscaling:autoScalingGroup:DesiredCapacity</code> - The desired capacity of an Auto Scaling group.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>ecs:service:DesiredCount</code> - The desired task count of an ECS service.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>ec2:spot-fleet-request:TargetCapacity</code> - The target capacity of a Spot Fleet request.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:table:ReadCapacityUnits</code> - The provisioned read capacity for a DynamoDB table.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:table:WriteCapacityUnits</code> - The provisioned write capacity for a DynamoDB table.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:index:ReadCapacityUnits</code> - The provisioned read capacity for a DynamoDB global secondary
     * index.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:index:WriteCapacityUnits</code> - The provisioned write capacity for a DynamoDB global secondary
     * index.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>rds:cluster:ReadReplicaCount</code> - The count of Aurora Replicas in an Aurora DB cluster. Available for
     * Aurora MySQL-compatible edition and Aurora PostgreSQL-compatible edition.
     * </p>
     * </li>
     * </ul>
     */
    private String scalableDimension;
    /**
     * <p>
     * The minimum capacity of the resource.
     * </p>
     */
    private Integer minCapacity;
    /**
     * <p>
     * The maximum capacity of the resource. The exception to this upper limit is if you specify a non-default setting
     * for <b>PredictiveScalingMaxCapacityBehavior</b>.
     * </p>
     */
    private Integer maxCapacity;
    /**
     * <p>
     * The target tracking configurations (up to 10). Each of these structures must specify a unique scaling metric and
     * a target value for the metric.
     * </p>
     */
    private java.util.List<TargetTrackingConfiguration> targetTrackingConfigurations;
    /**
     * <p>
     * The predefined load metric to use for predictive scaling. This parameter or a
     * <b>CustomizedLoadMetricSpecification</b> is required when configuring predictive scaling, and cannot be used
     * otherwise.
     * </p>
     */
    private PredefinedLoadMetricSpecification predefinedLoadMetricSpecification;
    /**
     * <p>
     * The customized load metric to use for predictive scaling. This parameter or a
     * <b>PredefinedLoadMetricSpecification</b> is required when configuring predictive scaling, and cannot be used
     * otherwise.
     * </p>
     */
    private CustomizedLoadMetricSpecification customizedLoadMetricSpecification;
    /**
     * <p>
     * The amount of time, in seconds, to buffer the run time of scheduled scaling actions when scaling out. For
     * example, if the forecast says to add capacity at 10:00 AM, and the buffer time is 5 minutes, then the run time of
     * the corresponding scheduled scaling action will be 9:55 AM. The intention is to give resources time to be
     * provisioned. For example, it can take a few minutes to launch an EC2 instance. The actual amount of time required
     * depends on several factors, such as the size of the instance and whether there are startup scripts to complete.
     * </p>
     * <p>
     * The value must be less than the forecast interval duration of 3600 seconds (60 minutes). The default is 300
     * seconds.
     * </p>
     * <p>
     * Only valid when configuring predictive scaling.
     * </p>
     */
    private Integer scheduledActionBufferTime;
    /**
     * <p>
     * Defines the behavior that should be applied if the forecast capacity approaches or exceeds the maximum capacity
     * specified for the resource. The default value is <code>SetForecastCapacityToMaxCapacity</code>.
     * </p>
     * <p>
     * The following are possible values:
     * </p>
     * <ul>
     * <li>
     * <p>
     * <code>SetForecastCapacityToMaxCapacity</code> - AWS Auto Scaling cannot scale resource capacity higher than the
     * maximum capacity. The maximum capacity is enforced as a hard limit.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>SetMaxCapacityToForecastCapacity</code> - AWS Auto Scaling may scale resource capacity higher than the
     * maximum capacity to equal but not exceed forecast capacity.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>SetMaxCapacityAboveForecastCapacity</code> - AWS Auto Scaling may scale resource capacity higher than the
     * maximum capacity by a specified buffer value. The intention is to give the target tracking scaling policy extra
     * capacity if unexpected traffic occurs.
     * </p>
     * </li>
     * </ul>
     * <p>
     * Only valid when configuring predictive scaling.
     * </p>
     */
    private String predictiveScalingMaxCapacityBehavior;
    /**
     * <p>
     * The size of the capacity buffer to use when the forecast capacity is close to or exceeds the maximum capacity.
     * The value is specified as a percentage relative to the forecast capacity. For example, if the buffer is 10, this
     * means a 10 percent buffer, such that if the forecast capacity is 50, and the maximum capacity is 40, then the
     * effective maximum capacity is 55.
     * </p>
     * <p>
     * Only valid when configuring predictive scaling. Required if the <b>PredictiveScalingMaxCapacityBehavior</b> is
     * set to <code>SetMaxCapacityAboveForecastCapacity</code>, and cannot be used otherwise.
     * </p>
     * <p>
     * The range is 1-100.
     * </p>
     */
    private Integer predictiveScalingMaxCapacityBuffer;
    /**
     * <p>
     * The predictive scaling mode. The default value is <code>ForecastAndScale</code>. Otherwise, AWS Auto Scaling
     * forecasts capacity but does not create any scheduled scaling actions based on the capacity forecast.
     * </p>
     */
    private String predictiveScalingMode;
    /**
     * <p>
     * Controls whether a resource's externally created scaling policies are kept or replaced.
     * </p>
     * <p>
     * The default value is <code>KeepExternalPolicies</code>. If the parameter is set to
     * <code>ReplaceExternalPolicies</code>, any scaling policies that are external to AWS Auto Scaling are deleted and
     * new target tracking scaling policies created.
     * </p>
     * <p>
     * Only valid when configuring dynamic scaling.
     * </p>
     * <p>
     * Condition: The number of existing policies to be replaced must be less than or equal to 50. If there are more
     * than 50 policies to be replaced, AWS Auto Scaling keeps all existing policies and does not create new ones.
     * </p>
     */
    private String scalingPolicyUpdateBehavior;
    /**
     * <p>
     * Controls whether dynamic scaling by AWS Auto Scaling is disabled. When dynamic scaling is enabled, AWS Auto
     * Scaling creates target tracking scaling policies based on the specified target tracking configurations.
     * </p>
     * <p>
     * The default is enabled (<code>false</code>).
     * </p>
     */
    private Boolean disableDynamicScaling;

    /**
     * <p>
     * The namespace of the AWS service.
     * </p>
     * 
     * @param serviceNamespace
     *        The namespace of the AWS service.
     * @see ServiceNamespace
     */

    public void setServiceNamespace(String serviceNamespace) {
        this.serviceNamespace = serviceNamespace;
    }

    /**
     * <p>
     * The namespace of the AWS service.
     * </p>
     * 
     * @return The namespace of the AWS service.
     * @see ServiceNamespace
     */

    public String getServiceNamespace() {
        return this.serviceNamespace;
    }

    /**
     * <p>
     * The namespace of the AWS service.
     * </p>
     * 
     * @param serviceNamespace
     *        The namespace of the AWS service.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see ServiceNamespace
     */

    public ScalingInstruction withServiceNamespace(String serviceNamespace) {
        setServiceNamespace(serviceNamespace);
        return this;
    }

    /**
     * <p>
     * The namespace of the AWS service.
     * </p>
     * 
     * @param serviceNamespace
     *        The namespace of the AWS service.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see ServiceNamespace
     */

    public ScalingInstruction withServiceNamespace(ServiceNamespace serviceNamespace) {
        this.serviceNamespace = serviceNamespace.toString();
        return this;
    }

    /**
     * <p>
     * The ID of the resource. This string consists of the resource type and unique identifier.
     * </p>
     * <ul>
     * <li>
     * <p>
     * Auto Scaling group - The resource type is <code>autoScalingGroup</code> and the unique identifier is the name of
     * the Auto Scaling group. Example: <code>autoScalingGroup/my-asg</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * ECS service - The resource type is <code>service</code> and the unique identifier is the cluster name and service
     * name. Example: <code>service/default/sample-webapp</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * Spot Fleet request - The resource type is <code>spot-fleet-request</code> and the unique identifier is the Spot
     * Fleet request ID. Example: <code>spot-fleet-request/sfr-73fbd2ce-aa30-494c-8788-1cee4EXAMPLE</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * DynamoDB table - The resource type is <code>table</code> and the unique identifier is the resource ID. Example:
     * <code>table/my-table</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * DynamoDB global secondary index - The resource type is <code>index</code> and the unique identifier is the
     * resource ID. Example: <code>table/my-table/index/my-table-index</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * Aurora DB cluster - The resource type is <code>cluster</code> and the unique identifier is the cluster name.
     * Example: <code>cluster:my-db-cluster</code>.
     * </p>
     * </li>
     * </ul>
     * 
     * @param resourceId
     *        The ID of the resource. This string consists of the resource type and unique identifier.</p>
     *        <ul>
     *        <li>
     *        <p>
     *        Auto Scaling group - The resource type is <code>autoScalingGroup</code> and the unique identifier is the
     *        name of the Auto Scaling group. Example: <code>autoScalingGroup/my-asg</code>.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        ECS service - The resource type is <code>service</code> and the unique identifier is the cluster name and
     *        service name. Example: <code>service/default/sample-webapp</code>.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        Spot Fleet request - The resource type is <code>spot-fleet-request</code> and the unique identifier is the
     *        Spot Fleet request ID. Example: <code>spot-fleet-request/sfr-73fbd2ce-aa30-494c-8788-1cee4EXAMPLE</code>.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        DynamoDB table - The resource type is <code>table</code> and the unique identifier is the resource ID.
     *        Example: <code>table/my-table</code>.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        DynamoDB global secondary index - The resource type is <code>index</code> and the unique identifier is the
     *        resource ID. Example: <code>table/my-table/index/my-table-index</code>.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        Aurora DB cluster - The resource type is <code>cluster</code> and the unique identifier is the cluster
     *        name. Example: <code>cluster:my-db-cluster</code>.
     *        </p>
     *        </li>
     */

    public void setResourceId(String resourceId) {
        this.resourceId = resourceId;
    }

    /**
     * <p>
     * The ID of the resource. This string consists of the resource type and unique identifier.
     * </p>
     * <ul>
     * <li>
     * <p>
     * Auto Scaling group - The resource type is <code>autoScalingGroup</code> and the unique identifier is the name of
     * the Auto Scaling group. Example: <code>autoScalingGroup/my-asg</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * ECS service - The resource type is <code>service</code> and the unique identifier is the cluster name and service
     * name. Example: <code>service/default/sample-webapp</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * Spot Fleet request - The resource type is <code>spot-fleet-request</code> and the unique identifier is the Spot
     * Fleet request ID. Example: <code>spot-fleet-request/sfr-73fbd2ce-aa30-494c-8788-1cee4EXAMPLE</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * DynamoDB table - The resource type is <code>table</code> and the unique identifier is the resource ID. Example:
     * <code>table/my-table</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * DynamoDB global secondary index - The resource type is <code>index</code> and the unique identifier is the
     * resource ID. Example: <code>table/my-table/index/my-table-index</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * Aurora DB cluster - The resource type is <code>cluster</code> and the unique identifier is the cluster name.
     * Example: <code>cluster:my-db-cluster</code>.
     * </p>
     * </li>
     * </ul>
     * 
     * @return The ID of the resource. This string consists of the resource type and unique identifier.</p>
     *         <ul>
     *         <li>
     *         <p>
     *         Auto Scaling group - The resource type is <code>autoScalingGroup</code> and the unique identifier is the
     *         name of the Auto Scaling group. Example: <code>autoScalingGroup/my-asg</code>.
     *         </p>
     *         </li>
     *         <li>
     *         <p>
     *         ECS service - The resource type is <code>service</code> and the unique identifier is the cluster name and
     *         service name. Example: <code>service/default/sample-webapp</code>.
     *         </p>
     *         </li>
     *         <li>
     *         <p>
     *         Spot Fleet request - The resource type is <code>spot-fleet-request</code> and the unique identifier is
     *         the Spot Fleet request ID. Example:
     *         <code>spot-fleet-request/sfr-73fbd2ce-aa30-494c-8788-1cee4EXAMPLE</code>.
     *         </p>
     *         </li>
     *         <li>
     *         <p>
     *         DynamoDB table - The resource type is <code>table</code> and the unique identifier is the resource ID.
     *         Example: <code>table/my-table</code>.
     *         </p>
     *         </li>
     *         <li>
     *         <p>
     *         DynamoDB global secondary index - The resource type is <code>index</code> and the unique identifier is
     *         the resource ID. Example: <code>table/my-table/index/my-table-index</code>.
     *         </p>
     *         </li>
     *         <li>
     *         <p>
     *         Aurora DB cluster - The resource type is <code>cluster</code> and the unique identifier is the cluster
     *         name. Example: <code>cluster:my-db-cluster</code>.
     *         </p>
     *         </li>
     */

    public String getResourceId() {
        return this.resourceId;
    }

    /**
     * <p>
     * The ID of the resource. This string consists of the resource type and unique identifier.
     * </p>
     * <ul>
     * <li>
     * <p>
     * Auto Scaling group - The resource type is <code>autoScalingGroup</code> and the unique identifier is the name of
     * the Auto Scaling group. Example: <code>autoScalingGroup/my-asg</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * ECS service - The resource type is <code>service</code> and the unique identifier is the cluster name and service
     * name. Example: <code>service/default/sample-webapp</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * Spot Fleet request - The resource type is <code>spot-fleet-request</code> and the unique identifier is the Spot
     * Fleet request ID. Example: <code>spot-fleet-request/sfr-73fbd2ce-aa30-494c-8788-1cee4EXAMPLE</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * DynamoDB table - The resource type is <code>table</code> and the unique identifier is the resource ID. Example:
     * <code>table/my-table</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * DynamoDB global secondary index - The resource type is <code>index</code> and the unique identifier is the
     * resource ID. Example: <code>table/my-table/index/my-table-index</code>.
     * </p>
     * </li>
     * <li>
     * <p>
     * Aurora DB cluster - The resource type is <code>cluster</code> and the unique identifier is the cluster name.
     * Example: <code>cluster:my-db-cluster</code>.
     * </p>
     * </li>
     * </ul>
     * 
     * @param resourceId
     *        The ID of the resource. This string consists of the resource type and unique identifier.</p>
     *        <ul>
     *        <li>
     *        <p>
     *        Auto Scaling group - The resource type is <code>autoScalingGroup</code> and the unique identifier is the
     *        name of the Auto Scaling group. Example: <code>autoScalingGroup/my-asg</code>.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        ECS service - The resource type is <code>service</code> and the unique identifier is the cluster name and
     *        service name. Example: <code>service/default/sample-webapp</code>.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        Spot Fleet request - The resource type is <code>spot-fleet-request</code> and the unique identifier is the
     *        Spot Fleet request ID. Example: <code>spot-fleet-request/sfr-73fbd2ce-aa30-494c-8788-1cee4EXAMPLE</code>.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        DynamoDB table - The resource type is <code>table</code> and the unique identifier is the resource ID.
     *        Example: <code>table/my-table</code>.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        DynamoDB global secondary index - The resource type is <code>index</code> and the unique identifier is the
     *        resource ID. Example: <code>table/my-table/index/my-table-index</code>.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        Aurora DB cluster - The resource type is <code>cluster</code> and the unique identifier is the cluster
     *        name. Example: <code>cluster:my-db-cluster</code>.
     *        </p>
     *        </li>
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public ScalingInstruction withResourceId(String resourceId) {
        setResourceId(resourceId);
        return this;
    }

    /**
     * <p>
     * The scalable dimension associated with the resource.
     * </p>
     * <ul>
     * <li>
     * <p>
     * <code>autoscaling:autoScalingGroup:DesiredCapacity</code> - The desired capacity of an Auto Scaling group.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>ecs:service:DesiredCount</code> - The desired task count of an ECS service.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>ec2:spot-fleet-request:TargetCapacity</code> - The target capacity of a Spot Fleet request.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:table:ReadCapacityUnits</code> - The provisioned read capacity for a DynamoDB table.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:table:WriteCapacityUnits</code> - The provisioned write capacity for a DynamoDB table.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:index:ReadCapacityUnits</code> - The provisioned read capacity for a DynamoDB global secondary
     * index.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:index:WriteCapacityUnits</code> - The provisioned write capacity for a DynamoDB global secondary
     * index.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>rds:cluster:ReadReplicaCount</code> - The count of Aurora Replicas in an Aurora DB cluster. Available for
     * Aurora MySQL-compatible edition and Aurora PostgreSQL-compatible edition.
     * </p>
     * </li>
     * </ul>
     * 
     * @param scalableDimension
     *        The scalable dimension associated with the resource.</p>
     *        <ul>
     *        <li>
     *        <p>
     *        <code>autoscaling:autoScalingGroup:DesiredCapacity</code> - The desired capacity of an Auto Scaling group.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>ecs:service:DesiredCount</code> - The desired task count of an ECS service.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>ec2:spot-fleet-request:TargetCapacity</code> - The target capacity of a Spot Fleet request.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>dynamodb:table:ReadCapacityUnits</code> - The provisioned read capacity for a DynamoDB table.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>dynamodb:table:WriteCapacityUnits</code> - The provisioned write capacity for a DynamoDB table.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>dynamodb:index:ReadCapacityUnits</code> - The provisioned read capacity for a DynamoDB global
     *        secondary index.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>dynamodb:index:WriteCapacityUnits</code> - The provisioned write capacity for a DynamoDB global
     *        secondary index.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>rds:cluster:ReadReplicaCount</code> - The count of Aurora Replicas in an Aurora DB cluster.
     *        Available for Aurora MySQL-compatible edition and Aurora PostgreSQL-compatible edition.
     *        </p>
     *        </li>
     * @see ScalableDimension
     */

    public void setScalableDimension(String scalableDimension) {
        this.scalableDimension = scalableDimension;
    }

    /**
     * <p>
     * The scalable dimension associated with the resource.
     * </p>
     * <ul>
     * <li>
     * <p>
     * <code>autoscaling:autoScalingGroup:DesiredCapacity</code> - The desired capacity of an Auto Scaling group.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>ecs:service:DesiredCount</code> - The desired task count of an ECS service.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>ec2:spot-fleet-request:TargetCapacity</code> - The target capacity of a Spot Fleet request.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:table:ReadCapacityUnits</code> - The provisioned read capacity for a DynamoDB table.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:table:WriteCapacityUnits</code> - The provisioned write capacity for a DynamoDB table.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:index:ReadCapacityUnits</code> - The provisioned read capacity for a DynamoDB global secondary
     * index.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:index:WriteCapacityUnits</code> - The provisioned write capacity for a DynamoDB global secondary
     * index.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>rds:cluster:ReadReplicaCount</code> - The count of Aurora Replicas in an Aurora DB cluster. Available for
     * Aurora MySQL-compatible edition and Aurora PostgreSQL-compatible edition.
     * </p>
     * </li>
     * </ul>
     * 
     * @return The scalable dimension associated with the resource.</p>
     *         <ul>
     *         <li>
     *         <p>
     *         <code>autoscaling:autoScalingGroup:DesiredCapacity</code> - The desired capacity of an Auto Scaling
     *         group.
     *         </p>
     *         </li>
     *         <li>
     *         <p>
     *         <code>ecs:service:DesiredCount</code> - The desired task count of an ECS service.
     *         </p>
     *         </li>
     *         <li>
     *         <p>
     *         <code>ec2:spot-fleet-request:TargetCapacity</code> - The target capacity of a Spot Fleet request.
     *         </p>
     *         </li>
     *         <li>
     *         <p>
     *         <code>dynamodb:table:ReadCapacityUnits</code> - The provisioned read capacity for a DynamoDB table.
     *         </p>
     *         </li>
     *         <li>
     *         <p>
     *         <code>dynamodb:table:WriteCapacityUnits</code> - The provisioned write capacity for a DynamoDB table.
     *         </p>
     *         </li>
     *         <li>
     *         <p>
     *         <code>dynamodb:index:ReadCapacityUnits</code> - The provisioned read capacity for a DynamoDB global
     *         secondary index.
     *         </p>
     *         </li>
     *         <li>
     *         <p>
     *         <code>dynamodb:index:WriteCapacityUnits</code> - The provisioned write capacity for a DynamoDB global
     *         secondary index.
     *         </p>
     *         </li>
     *         <li>
     *         <p>
     *         <code>rds:cluster:ReadReplicaCount</code> - The count of Aurora Replicas in an Aurora DB cluster.
     *         Available for Aurora MySQL-compatible edition and Aurora PostgreSQL-compatible edition.
     *         </p>
     *         </li>
     * @see ScalableDimension
     */

    public String getScalableDimension() {
        return this.scalableDimension;
    }

    /**
     * <p>
     * The scalable dimension associated with the resource.
     * </p>
     * <ul>
     * <li>
     * <p>
     * <code>autoscaling:autoScalingGroup:DesiredCapacity</code> - The desired capacity of an Auto Scaling group.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>ecs:service:DesiredCount</code> - The desired task count of an ECS service.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>ec2:spot-fleet-request:TargetCapacity</code> - The target capacity of a Spot Fleet request.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:table:ReadCapacityUnits</code> - The provisioned read capacity for a DynamoDB table.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:table:WriteCapacityUnits</code> - The provisioned write capacity for a DynamoDB table.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:index:ReadCapacityUnits</code> - The provisioned read capacity for a DynamoDB global secondary
     * index.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:index:WriteCapacityUnits</code> - The provisioned write capacity for a DynamoDB global secondary
     * index.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>rds:cluster:ReadReplicaCount</code> - The count of Aurora Replicas in an Aurora DB cluster. Available for
     * Aurora MySQL-compatible edition and Aurora PostgreSQL-compatible edition.
     * </p>
     * </li>
     * </ul>
     * 
     * @param scalableDimension
     *        The scalable dimension associated with the resource.</p>
     *        <ul>
     *        <li>
     *        <p>
     *        <code>autoscaling:autoScalingGroup:DesiredCapacity</code> - The desired capacity of an Auto Scaling group.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>ecs:service:DesiredCount</code> - The desired task count of an ECS service.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>ec2:spot-fleet-request:TargetCapacity</code> - The target capacity of a Spot Fleet request.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>dynamodb:table:ReadCapacityUnits</code> - The provisioned read capacity for a DynamoDB table.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>dynamodb:table:WriteCapacityUnits</code> - The provisioned write capacity for a DynamoDB table.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>dynamodb:index:ReadCapacityUnits</code> - The provisioned read capacity for a DynamoDB global
     *        secondary index.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>dynamodb:index:WriteCapacityUnits</code> - The provisioned write capacity for a DynamoDB global
     *        secondary index.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>rds:cluster:ReadReplicaCount</code> - The count of Aurora Replicas in an Aurora DB cluster.
     *        Available for Aurora MySQL-compatible edition and Aurora PostgreSQL-compatible edition.
     *        </p>
     *        </li>
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see ScalableDimension
     */

    public ScalingInstruction withScalableDimension(String scalableDimension) {
        setScalableDimension(scalableDimension);
        return this;
    }

    /**
     * <p>
     * The scalable dimension associated with the resource.
     * </p>
     * <ul>
     * <li>
     * <p>
     * <code>autoscaling:autoScalingGroup:DesiredCapacity</code> - The desired capacity of an Auto Scaling group.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>ecs:service:DesiredCount</code> - The desired task count of an ECS service.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>ec2:spot-fleet-request:TargetCapacity</code> - The target capacity of a Spot Fleet request.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:table:ReadCapacityUnits</code> - The provisioned read capacity for a DynamoDB table.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:table:WriteCapacityUnits</code> - The provisioned write capacity for a DynamoDB table.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:index:ReadCapacityUnits</code> - The provisioned read capacity for a DynamoDB global secondary
     * index.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>dynamodb:index:WriteCapacityUnits</code> - The provisioned write capacity for a DynamoDB global secondary
     * index.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>rds:cluster:ReadReplicaCount</code> - The count of Aurora Replicas in an Aurora DB cluster. Available for
     * Aurora MySQL-compatible edition and Aurora PostgreSQL-compatible edition.
     * </p>
     * </li>
     * </ul>
     * 
     * @param scalableDimension
     *        The scalable dimension associated with the resource.</p>
     *        <ul>
     *        <li>
     *        <p>
     *        <code>autoscaling:autoScalingGroup:DesiredCapacity</code> - The desired capacity of an Auto Scaling group.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>ecs:service:DesiredCount</code> - The desired task count of an ECS service.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>ec2:spot-fleet-request:TargetCapacity</code> - The target capacity of a Spot Fleet request.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>dynamodb:table:ReadCapacityUnits</code> - The provisioned read capacity for a DynamoDB table.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>dynamodb:table:WriteCapacityUnits</code> - The provisioned write capacity for a DynamoDB table.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>dynamodb:index:ReadCapacityUnits</code> - The provisioned read capacity for a DynamoDB global
     *        secondary index.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>dynamodb:index:WriteCapacityUnits</code> - The provisioned write capacity for a DynamoDB global
     *        secondary index.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>rds:cluster:ReadReplicaCount</code> - The count of Aurora Replicas in an Aurora DB cluster.
     *        Available for Aurora MySQL-compatible edition and Aurora PostgreSQL-compatible edition.
     *        </p>
     *        </li>
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see ScalableDimension
     */

    public ScalingInstruction withScalableDimension(ScalableDimension scalableDimension) {
        this.scalableDimension = scalableDimension.toString();
        return this;
    }

    /**
     * <p>
     * The minimum capacity of the resource.
     * </p>
     * 
     * @param minCapacity
     *        The minimum capacity of the resource.
     */

    public void setMinCapacity(Integer minCapacity) {
        this.minCapacity = minCapacity;
    }

    /**
     * <p>
     * The minimum capacity of the resource.
     * </p>
     * 
     * @return The minimum capacity of the resource.
     */

    public Integer getMinCapacity() {
        return this.minCapacity;
    }

    /**
     * <p>
     * The minimum capacity of the resource.
     * </p>
     * 
     * @param minCapacity
     *        The minimum capacity of the resource.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public ScalingInstruction withMinCapacity(Integer minCapacity) {
        setMinCapacity(minCapacity);
        return this;
    }

    /**
     * <p>
     * The maximum capacity of the resource. The exception to this upper limit is if you specify a non-default setting
     * for <b>PredictiveScalingMaxCapacityBehavior</b>.
     * </p>
     * 
     * @param maxCapacity
     *        The maximum capacity of the resource. The exception to this upper limit is if you specify a non-default
     *        setting for <b>PredictiveScalingMaxCapacityBehavior</b>.
     */

    public void setMaxCapacity(Integer maxCapacity) {
        this.maxCapacity = maxCapacity;
    }

    /**
     * <p>
     * The maximum capacity of the resource. The exception to this upper limit is if you specify a non-default setting
     * for <b>PredictiveScalingMaxCapacityBehavior</b>.
     * </p>
     * 
     * @return The maximum capacity of the resource. The exception to this upper limit is if you specify a non-default
     *         setting for <b>PredictiveScalingMaxCapacityBehavior</b>.
     */

    public Integer getMaxCapacity() {
        return this.maxCapacity;
    }

    /**
     * <p>
     * The maximum capacity of the resource. The exception to this upper limit is if you specify a non-default setting
     * for <b>PredictiveScalingMaxCapacityBehavior</b>.
     * </p>
     * 
     * @param maxCapacity
     *        The maximum capacity of the resource. The exception to this upper limit is if you specify a non-default
     *        setting for <b>PredictiveScalingMaxCapacityBehavior</b>.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public ScalingInstruction withMaxCapacity(Integer maxCapacity) {
        setMaxCapacity(maxCapacity);
        return this;
    }

    /**
     * <p>
     * The target tracking configurations (up to 10). Each of these structures must specify a unique scaling metric and
     * a target value for the metric.
     * </p>
     * 
     * @return The target tracking configurations (up to 10). Each of these structures must specify a unique scaling
     *         metric and a target value for the metric.
     */

    public java.util.List<TargetTrackingConfiguration> getTargetTrackingConfigurations() {
        return targetTrackingConfigurations;
    }

    /**
     * <p>
     * The target tracking configurations (up to 10). Each of these structures must specify a unique scaling metric and
     * a target value for the metric.
     * </p>
     * 
     * @param targetTrackingConfigurations
     *        The target tracking configurations (up to 10). Each of these structures must specify a unique scaling
     *        metric and a target value for the metric.
     */

    public void setTargetTrackingConfigurations(java.util.Collection<TargetTrackingConfiguration> targetTrackingConfigurations) {
        if (targetTrackingConfigurations == null) {
            this.targetTrackingConfigurations = null;
            return;
        }

        this.targetTrackingConfigurations = new java.util.ArrayList<TargetTrackingConfiguration>(targetTrackingConfigurations);
    }

    /**
     * <p>
     * The target tracking configurations (up to 10). Each of these structures must specify a unique scaling metric and
     * a target value for the metric.
     * </p>
     * <p>
     * <b>NOTE:</b> This method appends the values to the existing list (if any). Use
     * {@link #setTargetTrackingConfigurations(java.util.Collection)} or
     * {@link #withTargetTrackingConfigurations(java.util.Collection)} if you want to override the existing values.
     * </p>
     * 
     * @param targetTrackingConfigurations
     *        The target tracking configurations (up to 10). Each of these structures must specify a unique scaling
     *        metric and a target value for the metric.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public ScalingInstruction withTargetTrackingConfigurations(TargetTrackingConfiguration... targetTrackingConfigurations) {
        if (this.targetTrackingConfigurations == null) {
            setTargetTrackingConfigurations(new java.util.ArrayList<TargetTrackingConfiguration>(targetTrackingConfigurations.length));
        }
        for (TargetTrackingConfiguration ele : targetTrackingConfigurations) {
            this.targetTrackingConfigurations.add(ele);
        }
        return this;
    }

    /**
     * <p>
     * The target tracking configurations (up to 10). Each of these structures must specify a unique scaling metric and
     * a target value for the metric.
     * </p>
     * 
     * @param targetTrackingConfigurations
     *        The target tracking configurations (up to 10). Each of these structures must specify a unique scaling
     *        metric and a target value for the metric.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public ScalingInstruction withTargetTrackingConfigurations(java.util.Collection<TargetTrackingConfiguration> targetTrackingConfigurations) {
        setTargetTrackingConfigurations(targetTrackingConfigurations);
        return this;
    }

    /**
     * <p>
     * The predefined load metric to use for predictive scaling. This parameter or a
     * <b>CustomizedLoadMetricSpecification</b> is required when configuring predictive scaling, and cannot be used
     * otherwise.
     * </p>
     * 
     * @param predefinedLoadMetricSpecification
     *        The predefined load metric to use for predictive scaling. This parameter or a
     *        <b>CustomizedLoadMetricSpecification</b> is required when configuring predictive scaling, and cannot be
     *        used otherwise.
     */

    public void setPredefinedLoadMetricSpecification(PredefinedLoadMetricSpecification predefinedLoadMetricSpecification) {
        this.predefinedLoadMetricSpecification = predefinedLoadMetricSpecification;
    }

    /**
     * <p>
     * The predefined load metric to use for predictive scaling. This parameter or a
     * <b>CustomizedLoadMetricSpecification</b> is required when configuring predictive scaling, and cannot be used
     * otherwise.
     * </p>
     * 
     * @return The predefined load metric to use for predictive scaling. This parameter or a
     *         <b>CustomizedLoadMetricSpecification</b> is required when configuring predictive scaling, and cannot be
     *         used otherwise.
     */

    public PredefinedLoadMetricSpecification getPredefinedLoadMetricSpecification() {
        return this.predefinedLoadMetricSpecification;
    }

    /**
     * <p>
     * The predefined load metric to use for predictive scaling. This parameter or a
     * <b>CustomizedLoadMetricSpecification</b> is required when configuring predictive scaling, and cannot be used
     * otherwise.
     * </p>
     * 
     * @param predefinedLoadMetricSpecification
     *        The predefined load metric to use for predictive scaling. This parameter or a
     *        <b>CustomizedLoadMetricSpecification</b> is required when configuring predictive scaling, and cannot be
     *        used otherwise.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public ScalingInstruction withPredefinedLoadMetricSpecification(PredefinedLoadMetricSpecification predefinedLoadMetricSpecification) {
        setPredefinedLoadMetricSpecification(predefinedLoadMetricSpecification);
        return this;
    }

    /**
     * <p>
     * The customized load metric to use for predictive scaling. This parameter or a
     * <b>PredefinedLoadMetricSpecification</b> is required when configuring predictive scaling, and cannot be used
     * otherwise.
     * </p>
     * 
     * @param customizedLoadMetricSpecification
     *        The customized load metric to use for predictive scaling. This parameter or a
     *        <b>PredefinedLoadMetricSpecification</b> is required when configuring predictive scaling, and cannot be
     *        used otherwise.
     */

    public void setCustomizedLoadMetricSpecification(CustomizedLoadMetricSpecification customizedLoadMetricSpecification) {
        this.customizedLoadMetricSpecification = customizedLoadMetricSpecification;
    }

    /**
     * <p>
     * The customized load metric to use for predictive scaling. This parameter or a
     * <b>PredefinedLoadMetricSpecification</b> is required when configuring predictive scaling, and cannot be used
     * otherwise.
     * </p>
     * 
     * @return The customized load metric to use for predictive scaling. This parameter or a
     *         <b>PredefinedLoadMetricSpecification</b> is required when configuring predictive scaling, and cannot be
     *         used otherwise.
     */

    public CustomizedLoadMetricSpecification getCustomizedLoadMetricSpecification() {
        return this.customizedLoadMetricSpecification;
    }

    /**
     * <p>
     * The customized load metric to use for predictive scaling. This parameter or a
     * <b>PredefinedLoadMetricSpecification</b> is required when configuring predictive scaling, and cannot be used
     * otherwise.
     * </p>
     * 
     * @param customizedLoadMetricSpecification
     *        The customized load metric to use for predictive scaling. This parameter or a
     *        <b>PredefinedLoadMetricSpecification</b> is required when configuring predictive scaling, and cannot be
     *        used otherwise.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public ScalingInstruction withCustomizedLoadMetricSpecification(CustomizedLoadMetricSpecification customizedLoadMetricSpecification) {
        setCustomizedLoadMetricSpecification(customizedLoadMetricSpecification);
        return this;
    }

    /**
     * <p>
     * The amount of time, in seconds, to buffer the run time of scheduled scaling actions when scaling out. For
     * example, if the forecast says to add capacity at 10:00 AM, and the buffer time is 5 minutes, then the run time of
     * the corresponding scheduled scaling action will be 9:55 AM. The intention is to give resources time to be
     * provisioned. For example, it can take a few minutes to launch an EC2 instance. The actual amount of time required
     * depends on several factors, such as the size of the instance and whether there are startup scripts to complete.
     * </p>
     * <p>
     * The value must be less than the forecast interval duration of 3600 seconds (60 minutes). The default is 300
     * seconds.
     * </p>
     * <p>
     * Only valid when configuring predictive scaling.
     * </p>
     * 
     * @param scheduledActionBufferTime
     *        The amount of time, in seconds, to buffer the run time of scheduled scaling actions when scaling out. For
     *        example, if the forecast says to add capacity at 10:00 AM, and the buffer time is 5 minutes, then the run
     *        time of the corresponding scheduled scaling action will be 9:55 AM. The intention is to give resources
     *        time to be provisioned. For example, it can take a few minutes to launch an EC2 instance. The actual
     *        amount of time required depends on several factors, such as the size of the instance and whether there are
     *        startup scripts to complete. </p>
     *        <p>
     *        The value must be less than the forecast interval duration of 3600 seconds (60 minutes). The default is
     *        300 seconds.
     *        </p>
     *        <p>
     *        Only valid when configuring predictive scaling.
     */

    public void setScheduledActionBufferTime(Integer scheduledActionBufferTime) {
        this.scheduledActionBufferTime = scheduledActionBufferTime;
    }

    /**
     * <p>
     * The amount of time, in seconds, to buffer the run time of scheduled scaling actions when scaling out. For
     * example, if the forecast says to add capacity at 10:00 AM, and the buffer time is 5 minutes, then the run time of
     * the corresponding scheduled scaling action will be 9:55 AM. The intention is to give resources time to be
     * provisioned. For example, it can take a few minutes to launch an EC2 instance. The actual amount of time required
     * depends on several factors, such as the size of the instance and whether there are startup scripts to complete.
     * </p>
     * <p>
     * The value must be less than the forecast interval duration of 3600 seconds (60 minutes). The default is 300
     * seconds.
     * </p>
     * <p>
     * Only valid when configuring predictive scaling.
     * </p>
     * 
     * @return The amount of time, in seconds, to buffer the run time of scheduled scaling actions when scaling out. For
     *         example, if the forecast says to add capacity at 10:00 AM, and the buffer time is 5 minutes, then the run
     *         time of the corresponding scheduled scaling action will be 9:55 AM. The intention is to give resources
     *         time to be provisioned. For example, it can take a few minutes to launch an EC2 instance. The actual
     *         amount of time required depends on several factors, such as the size of the instance and whether there
     *         are startup scripts to complete. </p>
     *         <p>
     *         The value must be less than the forecast interval duration of 3600 seconds (60 minutes). The default is
     *         300 seconds.
     *         </p>
     *         <p>
     *         Only valid when configuring predictive scaling.
     */

    public Integer getScheduledActionBufferTime() {
        return this.scheduledActionBufferTime;
    }

    /**
     * <p>
     * The amount of time, in seconds, to buffer the run time of scheduled scaling actions when scaling out. For
     * example, if the forecast says to add capacity at 10:00 AM, and the buffer time is 5 minutes, then the run time of
     * the corresponding scheduled scaling action will be 9:55 AM. The intention is to give resources time to be
     * provisioned. For example, it can take a few minutes to launch an EC2 instance. The actual amount of time required
     * depends on several factors, such as the size of the instance and whether there are startup scripts to complete.
     * </p>
     * <p>
     * The value must be less than the forecast interval duration of 3600 seconds (60 minutes). The default is 300
     * seconds.
     * </p>
     * <p>
     * Only valid when configuring predictive scaling.
     * </p>
     * 
     * @param scheduledActionBufferTime
     *        The amount of time, in seconds, to buffer the run time of scheduled scaling actions when scaling out. For
     *        example, if the forecast says to add capacity at 10:00 AM, and the buffer time is 5 minutes, then the run
     *        time of the corresponding scheduled scaling action will be 9:55 AM. The intention is to give resources
     *        time to be provisioned. For example, it can take a few minutes to launch an EC2 instance. The actual
     *        amount of time required depends on several factors, such as the size of the instance and whether there are
     *        startup scripts to complete. </p>
     *        <p>
     *        The value must be less than the forecast interval duration of 3600 seconds (60 minutes). The default is
     *        300 seconds.
     *        </p>
     *        <p>
     *        Only valid when configuring predictive scaling.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public ScalingInstruction withScheduledActionBufferTime(Integer scheduledActionBufferTime) {
        setScheduledActionBufferTime(scheduledActionBufferTime);
        return this;
    }

    /**
     * <p>
     * Defines the behavior that should be applied if the forecast capacity approaches or exceeds the maximum capacity
     * specified for the resource. The default value is <code>SetForecastCapacityToMaxCapacity</code>.
     * </p>
     * <p>
     * The following are possible values:
     * </p>
     * <ul>
     * <li>
     * <p>
     * <code>SetForecastCapacityToMaxCapacity</code> - AWS Auto Scaling cannot scale resource capacity higher than the
     * maximum capacity. The maximum capacity is enforced as a hard limit.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>SetMaxCapacityToForecastCapacity</code> - AWS Auto Scaling may scale resource capacity higher than the
     * maximum capacity to equal but not exceed forecast capacity.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>SetMaxCapacityAboveForecastCapacity</code> - AWS Auto Scaling may scale resource capacity higher than the
     * maximum capacity by a specified buffer value. The intention is to give the target tracking scaling policy extra
     * capacity if unexpected traffic occurs.
     * </p>
     * </li>
     * </ul>
     * <p>
     * Only valid when configuring predictive scaling.
     * </p>
     * 
     * @param predictiveScalingMaxCapacityBehavior
     *        Defines the behavior that should be applied if the forecast capacity approaches or exceeds the maximum
     *        capacity specified for the resource. The default value is <code>SetForecastCapacityToMaxCapacity</code>
     *        .</p>
     *        <p>
     *        The following are possible values:
     *        </p>
     *        <ul>
     *        <li>
     *        <p>
     *        <code>SetForecastCapacityToMaxCapacity</code> - AWS Auto Scaling cannot scale resource capacity higher
     *        than the maximum capacity. The maximum capacity is enforced as a hard limit.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>SetMaxCapacityToForecastCapacity</code> - AWS Auto Scaling may scale resource capacity higher than
     *        the maximum capacity to equal but not exceed forecast capacity.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>SetMaxCapacityAboveForecastCapacity</code> - AWS Auto Scaling may scale resource capacity higher
     *        than the maximum capacity by a specified buffer value. The intention is to give the target tracking
     *        scaling policy extra capacity if unexpected traffic occurs.
     *        </p>
     *        </li>
     *        </ul>
     *        <p>
     *        Only valid when configuring predictive scaling.
     * @see PredictiveScalingMaxCapacityBehavior
     */

    public void setPredictiveScalingMaxCapacityBehavior(String predictiveScalingMaxCapacityBehavior) {
        this.predictiveScalingMaxCapacityBehavior = predictiveScalingMaxCapacityBehavior;
    }

    /**
     * <p>
     * Defines the behavior that should be applied if the forecast capacity approaches or exceeds the maximum capacity
     * specified for the resource. The default value is <code>SetForecastCapacityToMaxCapacity</code>.
     * </p>
     * <p>
     * The following are possible values:
     * </p>
     * <ul>
     * <li>
     * <p>
     * <code>SetForecastCapacityToMaxCapacity</code> - AWS Auto Scaling cannot scale resource capacity higher than the
     * maximum capacity. The maximum capacity is enforced as a hard limit.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>SetMaxCapacityToForecastCapacity</code> - AWS Auto Scaling may scale resource capacity higher than the
     * maximum capacity to equal but not exceed forecast capacity.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>SetMaxCapacityAboveForecastCapacity</code> - AWS Auto Scaling may scale resource capacity higher than the
     * maximum capacity by a specified buffer value. The intention is to give the target tracking scaling policy extra
     * capacity if unexpected traffic occurs.
     * </p>
     * </li>
     * </ul>
     * <p>
     * Only valid when configuring predictive scaling.
     * </p>
     * 
     * @return Defines the behavior that should be applied if the forecast capacity approaches or exceeds the maximum
     *         capacity specified for the resource. The default value is <code>SetForecastCapacityToMaxCapacity</code>
     *         .</p>
     *         <p>
     *         The following are possible values:
     *         </p>
     *         <ul>
     *         <li>
     *         <p>
     *         <code>SetForecastCapacityToMaxCapacity</code> - AWS Auto Scaling cannot scale resource capacity higher
     *         than the maximum capacity. The maximum capacity is enforced as a hard limit.
     *         </p>
     *         </li>
     *         <li>
     *         <p>
     *         <code>SetMaxCapacityToForecastCapacity</code> - AWS Auto Scaling may scale resource capacity higher than
     *         the maximum capacity to equal but not exceed forecast capacity.
     *         </p>
     *         </li>
     *         <li>
     *         <p>
     *         <code>SetMaxCapacityAboveForecastCapacity</code> - AWS Auto Scaling may scale resource capacity higher
     *         than the maximum capacity by a specified buffer value. The intention is to give the target tracking
     *         scaling policy extra capacity if unexpected traffic occurs.
     *         </p>
     *         </li>
     *         </ul>
     *         <p>
     *         Only valid when configuring predictive scaling.
     * @see PredictiveScalingMaxCapacityBehavior
     */

    public String getPredictiveScalingMaxCapacityBehavior() {
        return this.predictiveScalingMaxCapacityBehavior;
    }

    /**
     * <p>
     * Defines the behavior that should be applied if the forecast capacity approaches or exceeds the maximum capacity
     * specified for the resource. The default value is <code>SetForecastCapacityToMaxCapacity</code>.
     * </p>
     * <p>
     * The following are possible values:
     * </p>
     * <ul>
     * <li>
     * <p>
     * <code>SetForecastCapacityToMaxCapacity</code> - AWS Auto Scaling cannot scale resource capacity higher than the
     * maximum capacity. The maximum capacity is enforced as a hard limit.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>SetMaxCapacityToForecastCapacity</code> - AWS Auto Scaling may scale resource capacity higher than the
     * maximum capacity to equal but not exceed forecast capacity.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>SetMaxCapacityAboveForecastCapacity</code> - AWS Auto Scaling may scale resource capacity higher than the
     * maximum capacity by a specified buffer value. The intention is to give the target tracking scaling policy extra
     * capacity if unexpected traffic occurs.
     * </p>
     * </li>
     * </ul>
     * <p>
     * Only valid when configuring predictive scaling.
     * </p>
     * 
     * @param predictiveScalingMaxCapacityBehavior
     *        Defines the behavior that should be applied if the forecast capacity approaches or exceeds the maximum
     *        capacity specified for the resource. The default value is <code>SetForecastCapacityToMaxCapacity</code>
     *        .</p>
     *        <p>
     *        The following are possible values:
     *        </p>
     *        <ul>
     *        <li>
     *        <p>
     *        <code>SetForecastCapacityToMaxCapacity</code> - AWS Auto Scaling cannot scale resource capacity higher
     *        than the maximum capacity. The maximum capacity is enforced as a hard limit.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>SetMaxCapacityToForecastCapacity</code> - AWS Auto Scaling may scale resource capacity higher than
     *        the maximum capacity to equal but not exceed forecast capacity.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>SetMaxCapacityAboveForecastCapacity</code> - AWS Auto Scaling may scale resource capacity higher
     *        than the maximum capacity by a specified buffer value. The intention is to give the target tracking
     *        scaling policy extra capacity if unexpected traffic occurs.
     *        </p>
     *        </li>
     *        </ul>
     *        <p>
     *        Only valid when configuring predictive scaling.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see PredictiveScalingMaxCapacityBehavior
     */

    public ScalingInstruction withPredictiveScalingMaxCapacityBehavior(String predictiveScalingMaxCapacityBehavior) {
        setPredictiveScalingMaxCapacityBehavior(predictiveScalingMaxCapacityBehavior);
        return this;
    }

    /**
     * <p>
     * Defines the behavior that should be applied if the forecast capacity approaches or exceeds the maximum capacity
     * specified for the resource. The default value is <code>SetForecastCapacityToMaxCapacity</code>.
     * </p>
     * <p>
     * The following are possible values:
     * </p>
     * <ul>
     * <li>
     * <p>
     * <code>SetForecastCapacityToMaxCapacity</code> - AWS Auto Scaling cannot scale resource capacity higher than the
     * maximum capacity. The maximum capacity is enforced as a hard limit.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>SetMaxCapacityToForecastCapacity</code> - AWS Auto Scaling may scale resource capacity higher than the
     * maximum capacity to equal but not exceed forecast capacity.
     * </p>
     * </li>
     * <li>
     * <p>
     * <code>SetMaxCapacityAboveForecastCapacity</code> - AWS Auto Scaling may scale resource capacity higher than the
     * maximum capacity by a specified buffer value. The intention is to give the target tracking scaling policy extra
     * capacity if unexpected traffic occurs.
     * </p>
     * </li>
     * </ul>
     * <p>
     * Only valid when configuring predictive scaling.
     * </p>
     * 
     * @param predictiveScalingMaxCapacityBehavior
     *        Defines the behavior that should be applied if the forecast capacity approaches or exceeds the maximum
     *        capacity specified for the resource. The default value is <code>SetForecastCapacityToMaxCapacity</code>
     *        .</p>
     *        <p>
     *        The following are possible values:
     *        </p>
     *        <ul>
     *        <li>
     *        <p>
     *        <code>SetForecastCapacityToMaxCapacity</code> - AWS Auto Scaling cannot scale resource capacity higher
     *        than the maximum capacity. The maximum capacity is enforced as a hard limit.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>SetMaxCapacityToForecastCapacity</code> - AWS Auto Scaling may scale resource capacity higher than
     *        the maximum capacity to equal but not exceed forecast capacity.
     *        </p>
     *        </li>
     *        <li>
     *        <p>
     *        <code>SetMaxCapacityAboveForecastCapacity</code> - AWS Auto Scaling may scale resource capacity higher
     *        than the maximum capacity by a specified buffer value. The intention is to give the target tracking
     *        scaling policy extra capacity if unexpected traffic occurs.
     *        </p>
     *        </li>
     *        </ul>
     *        <p>
     *        Only valid when configuring predictive scaling.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see PredictiveScalingMaxCapacityBehavior
     */

    public ScalingInstruction withPredictiveScalingMaxCapacityBehavior(PredictiveScalingMaxCapacityBehavior predictiveScalingMaxCapacityBehavior) {
        this.predictiveScalingMaxCapacityBehavior = predictiveScalingMaxCapacityBehavior.toString();
        return this;
    }

    /**
     * <p>
     * The size of the capacity buffer to use when the forecast capacity is close to or exceeds the maximum capacity.
     * The value is specified as a percentage relative to the forecast capacity. For example, if the buffer is 10, this
     * means a 10 percent buffer, such that if the forecast capacity is 50, and the maximum capacity is 40, then the
     * effective maximum capacity is 55.
     * </p>
     * <p>
     * Only valid when configuring predictive scaling. Required if the <b>PredictiveScalingMaxCapacityBehavior</b> is
     * set to <code>SetMaxCapacityAboveForecastCapacity</code>, and cannot be used otherwise.
     * </p>
     * <p>
     * The range is 1-100.
     * </p>
     * 
     * @param predictiveScalingMaxCapacityBuffer
     *        The size of the capacity buffer to use when the forecast capacity is close to or exceeds the maximum
     *        capacity. The value is specified as a percentage relative to the forecast capacity. For example, if the
     *        buffer is 10, this means a 10 percent buffer, such that if the forecast capacity is 50, and the maximum
     *        capacity is 40, then the effective maximum capacity is 55.</p>
     *        <p>
     *        Only valid when configuring predictive scaling. Required if the
     *        <b>PredictiveScalingMaxCapacityBehavior</b> is set to <code>SetMaxCapacityAboveForecastCapacity</code>,
     *        and cannot be used otherwise.
     *        </p>
     *        <p>
     *        The range is 1-100.
     */

    public void setPredictiveScalingMaxCapacityBuffer(Integer predictiveScalingMaxCapacityBuffer) {
        this.predictiveScalingMaxCapacityBuffer = predictiveScalingMaxCapacityBuffer;
    }

    /**
     * <p>
     * The size of the capacity buffer to use when the forecast capacity is close to or exceeds the maximum capacity.
     * The value is specified as a percentage relative to the forecast capacity. For example, if the buffer is 10, this
     * means a 10 percent buffer, such that if the forecast capacity is 50, and the maximum capacity is 40, then the
     * effective maximum capacity is 55.
     * </p>
     * <p>
     * Only valid when configuring predictive scaling. Required if the <b>PredictiveScalingMaxCapacityBehavior</b> is
     * set to <code>SetMaxCapacityAboveForecastCapacity</code>, and cannot be used otherwise.
     * </p>
     * <p>
     * The range is 1-100.
     * </p>
     * 
     * @return The size of the capacity buffer to use when the forecast capacity is close to or exceeds the maximum
     *         capacity. The value is specified as a percentage relative to the forecast capacity. For example, if the
     *         buffer is 10, this means a 10 percent buffer, such that if the forecast capacity is 50, and the maximum
     *         capacity is 40, then the effective maximum capacity is 55.</p>
     *         <p>
     *         Only valid when configuring predictive scaling. Required if the
     *         <b>PredictiveScalingMaxCapacityBehavior</b> is set to <code>SetMaxCapacityAboveForecastCapacity</code>,
     *         and cannot be used otherwise.
     *         </p>
     *         <p>
     *         The range is 1-100.
     */

    public Integer getPredictiveScalingMaxCapacityBuffer() {
        return this.predictiveScalingMaxCapacityBuffer;
    }

    /**
     * <p>
     * The size of the capacity buffer to use when the forecast capacity is close to or exceeds the maximum capacity.
     * The value is specified as a percentage relative to the forecast capacity. For example, if the buffer is 10, this
     * means a 10 percent buffer, such that if the forecast capacity is 50, and the maximum capacity is 40, then the
     * effective maximum capacity is 55.
     * </p>
     * <p>
     * Only valid when configuring predictive scaling. Required if the <b>PredictiveScalingMaxCapacityBehavior</b> is
     * set to <code>SetMaxCapacityAboveForecastCapacity</code>, and cannot be used otherwise.
     * </p>
     * <p>
     * The range is 1-100.
     * </p>
     * 
     * @param predictiveScalingMaxCapacityBuffer
     *        The size of the capacity buffer to use when the forecast capacity is close to or exceeds the maximum
     *        capacity. The value is specified as a percentage relative to the forecast capacity. For example, if the
     *        buffer is 10, this means a 10 percent buffer, such that if the forecast capacity is 50, and the maximum
     *        capacity is 40, then the effective maximum capacity is 55.</p>
     *        <p>
     *        Only valid when configuring predictive scaling. Required if the
     *        <b>PredictiveScalingMaxCapacityBehavior</b> is set to <code>SetMaxCapacityAboveForecastCapacity</code>,
     *        and cannot be used otherwise.
     *        </p>
     *        <p>
     *        The range is 1-100.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public ScalingInstruction withPredictiveScalingMaxCapacityBuffer(Integer predictiveScalingMaxCapacityBuffer) {
        setPredictiveScalingMaxCapacityBuffer(predictiveScalingMaxCapacityBuffer);
        return this;
    }

    /**
     * <p>
     * The predictive scaling mode. The default value is <code>ForecastAndScale</code>. Otherwise, AWS Auto Scaling
     * forecasts capacity but does not create any scheduled scaling actions based on the capacity forecast.
     * </p>
     * 
     * @param predictiveScalingMode
     *        The predictive scaling mode. The default value is <code>ForecastAndScale</code>. Otherwise, AWS Auto
     *        Scaling forecasts capacity but does not create any scheduled scaling actions based on the capacity
     *        forecast.
     * @see PredictiveScalingMode
     */

    public void setPredictiveScalingMode(String predictiveScalingMode) {
        this.predictiveScalingMode = predictiveScalingMode;
    }

    /**
     * <p>
     * The predictive scaling mode. The default value is <code>ForecastAndScale</code>. Otherwise, AWS Auto Scaling
     * forecasts capacity but does not create any scheduled scaling actions based on the capacity forecast.
     * </p>
     * 
     * @return The predictive scaling mode. The default value is <code>ForecastAndScale</code>. Otherwise, AWS Auto
     *         Scaling forecasts capacity but does not create any scheduled scaling actions based on the capacity
     *         forecast.
     * @see PredictiveScalingMode
     */

    public String getPredictiveScalingMode() {
        return this.predictiveScalingMode;
    }

    /**
     * <p>
     * The predictive scaling mode. The default value is <code>ForecastAndScale</code>. Otherwise, AWS Auto Scaling
     * forecasts capacity but does not create any scheduled scaling actions based on the capacity forecast.
     * </p>
     * 
     * @param predictiveScalingMode
     *        The predictive scaling mode. The default value is <code>ForecastAndScale</code>. Otherwise, AWS Auto
     *        Scaling forecasts capacity but does not create any scheduled scaling actions based on the capacity
     *        forecast.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see PredictiveScalingMode
     */

    public ScalingInstruction withPredictiveScalingMode(String predictiveScalingMode) {
        setPredictiveScalingMode(predictiveScalingMode);
        return this;
    }

    /**
     * <p>
     * The predictive scaling mode. The default value is <code>ForecastAndScale</code>. Otherwise, AWS Auto Scaling
     * forecasts capacity but does not create any scheduled scaling actions based on the capacity forecast.
     * </p>
     * 
     * @param predictiveScalingMode
     *        The predictive scaling mode. The default value is <code>ForecastAndScale</code>. Otherwise, AWS Auto
     *        Scaling forecasts capacity but does not create any scheduled scaling actions based on the capacity
     *        forecast.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see PredictiveScalingMode
     */

    public ScalingInstruction withPredictiveScalingMode(PredictiveScalingMode predictiveScalingMode) {
        this.predictiveScalingMode = predictiveScalingMode.toString();
        return this;
    }

    /**
     * <p>
     * Controls whether a resource's externally created scaling policies are kept or replaced.
     * </p>
     * <p>
     * The default value is <code>KeepExternalPolicies</code>. If the parameter is set to
     * <code>ReplaceExternalPolicies</code>, any scaling policies that are external to AWS Auto Scaling are deleted and
     * new target tracking scaling policies created.
     * </p>
     * <p>
     * Only valid when configuring dynamic scaling.
     * </p>
     * <p>
     * Condition: The number of existing policies to be replaced must be less than or equal to 50. If there are more
     * than 50 policies to be replaced, AWS Auto Scaling keeps all existing policies and does not create new ones.
     * </p>
     * 
     * @param scalingPolicyUpdateBehavior
     *        Controls whether a resource's externally created scaling policies are kept or replaced. </p>
     *        <p>
     *        The default value is <code>KeepExternalPolicies</code>. If the parameter is set to
     *        <code>ReplaceExternalPolicies</code>, any scaling policies that are external to AWS Auto Scaling are
     *        deleted and new target tracking scaling policies created.
     *        </p>
     *        <p>
     *        Only valid when configuring dynamic scaling.
     *        </p>
     *        <p>
     *        Condition: The number of existing policies to be replaced must be less than or equal to 50. If there are
     *        more than 50 policies to be replaced, AWS Auto Scaling keeps all existing policies and does not create new
     *        ones.
     * @see ScalingPolicyUpdateBehavior
     */

    public void setScalingPolicyUpdateBehavior(String scalingPolicyUpdateBehavior) {
        this.scalingPolicyUpdateBehavior = scalingPolicyUpdateBehavior;
    }

    /**
     * <p>
     * Controls whether a resource's externally created scaling policies are kept or replaced.
     * </p>
     * <p>
     * The default value is <code>KeepExternalPolicies</code>. If the parameter is set to
     * <code>ReplaceExternalPolicies</code>, any scaling policies that are external to AWS Auto Scaling are deleted and
     * new target tracking scaling policies created.
     * </p>
     * <p>
     * Only valid when configuring dynamic scaling.
     * </p>
     * <p>
     * Condition: The number of existing policies to be replaced must be less than or equal to 50. If there are more
     * than 50 policies to be replaced, AWS Auto Scaling keeps all existing policies and does not create new ones.
     * </p>
     * 
     * @return Controls whether a resource's externally created scaling policies are kept or replaced. </p>
     *         <p>
     *         The default value is <code>KeepExternalPolicies</code>. If the parameter is set to
     *         <code>ReplaceExternalPolicies</code>, any scaling policies that are external to AWS Auto Scaling are
     *         deleted and new target tracking scaling policies created.
     *         </p>
     *         <p>
     *         Only valid when configuring dynamic scaling.
     *         </p>
     *         <p>
     *         Condition: The number of existing policies to be replaced must be less than or equal to 50. If there are
     *         more than 50 policies to be replaced, AWS Auto Scaling keeps all existing policies and does not create
     *         new ones.
     * @see ScalingPolicyUpdateBehavior
     */

    public String getScalingPolicyUpdateBehavior() {
        return this.scalingPolicyUpdateBehavior;
    }

    /**
     * <p>
     * Controls whether a resource's externally created scaling policies are kept or replaced.
     * </p>
     * <p>
     * The default value is <code>KeepExternalPolicies</code>. If the parameter is set to
     * <code>ReplaceExternalPolicies</code>, any scaling policies that are external to AWS Auto Scaling are deleted and
     * new target tracking scaling policies created.
     * </p>
     * <p>
     * Only valid when configuring dynamic scaling.
     * </p>
     * <p>
     * Condition: The number of existing policies to be replaced must be less than or equal to 50. If there are more
     * than 50 policies to be replaced, AWS Auto Scaling keeps all existing policies and does not create new ones.
     * </p>
     * 
     * @param scalingPolicyUpdateBehavior
     *        Controls whether a resource's externally created scaling policies are kept or replaced. </p>
     *        <p>
     *        The default value is <code>KeepExternalPolicies</code>. If the parameter is set to
     *        <code>ReplaceExternalPolicies</code>, any scaling policies that are external to AWS Auto Scaling are
     *        deleted and new target tracking scaling policies created.
     *        </p>
     *        <p>
     *        Only valid when configuring dynamic scaling.
     *        </p>
     *        <p>
     *        Condition: The number of existing policies to be replaced must be less than or equal to 50. If there are
     *        more than 50 policies to be replaced, AWS Auto Scaling keeps all existing policies and does not create new
     *        ones.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see ScalingPolicyUpdateBehavior
     */

    public ScalingInstruction withScalingPolicyUpdateBehavior(String scalingPolicyUpdateBehavior) {
        setScalingPolicyUpdateBehavior(scalingPolicyUpdateBehavior);
        return this;
    }

    /**
     * <p>
     * Controls whether a resource's externally created scaling policies are kept or replaced.
     * </p>
     * <p>
     * The default value is <code>KeepExternalPolicies</code>. If the parameter is set to
     * <code>ReplaceExternalPolicies</code>, any scaling policies that are external to AWS Auto Scaling are deleted and
     * new target tracking scaling policies created.
     * </p>
     * <p>
     * Only valid when configuring dynamic scaling.
     * </p>
     * <p>
     * Condition: The number of existing policies to be replaced must be less than or equal to 50. If there are more
     * than 50 policies to be replaced, AWS Auto Scaling keeps all existing policies and does not create new ones.
     * </p>
     * 
     * @param scalingPolicyUpdateBehavior
     *        Controls whether a resource's externally created scaling policies are kept or replaced. </p>
     *        <p>
     *        The default value is <code>KeepExternalPolicies</code>. If the parameter is set to
     *        <code>ReplaceExternalPolicies</code>, any scaling policies that are external to AWS Auto Scaling are
     *        deleted and new target tracking scaling policies created.
     *        </p>
     *        <p>
     *        Only valid when configuring dynamic scaling.
     *        </p>
     *        <p>
     *        Condition: The number of existing policies to be replaced must be less than or equal to 50. If there are
     *        more than 50 policies to be replaced, AWS Auto Scaling keeps all existing policies and does not create new
     *        ones.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see ScalingPolicyUpdateBehavior
     */

    public ScalingInstruction withScalingPolicyUpdateBehavior(ScalingPolicyUpdateBehavior scalingPolicyUpdateBehavior) {
        this.scalingPolicyUpdateBehavior = scalingPolicyUpdateBehavior.toString();
        return this;
    }

    /**
     * <p>
     * Controls whether dynamic scaling by AWS Auto Scaling is disabled. When dynamic scaling is enabled, AWS Auto
     * Scaling creates target tracking scaling policies based on the specified target tracking configurations.
     * </p>
     * <p>
     * The default is enabled (<code>false</code>).
     * </p>
     * 
     * @param disableDynamicScaling
     *        Controls whether dynamic scaling by AWS Auto Scaling is disabled. When dynamic scaling is enabled, AWS
     *        Auto Scaling creates target tracking scaling policies based on the specified target tracking
     *        configurations. </p>
     *        <p>
     *        The default is enabled (<code>false</code>).
     */

    public void setDisableDynamicScaling(Boolean disableDynamicScaling) {
        this.disableDynamicScaling = disableDynamicScaling;
    }

    /**
     * <p>
     * Controls whether dynamic scaling by AWS Auto Scaling is disabled. When dynamic scaling is enabled, AWS Auto
     * Scaling creates target tracking scaling policies based on the specified target tracking configurations.
     * </p>
     * <p>
     * The default is enabled (<code>false</code>).
     * </p>
     * 
     * @return Controls whether dynamic scaling by AWS Auto Scaling is disabled. When dynamic scaling is enabled, AWS
     *         Auto Scaling creates target tracking scaling policies based on the specified target tracking
     *         configurations. </p>
     *         <p>
     *         The default is enabled (<code>false</code>).
     */

    public Boolean getDisableDynamicScaling() {
        return this.disableDynamicScaling;
    }

    /**
     * <p>
     * Controls whether dynamic scaling by AWS Auto Scaling is disabled. When dynamic scaling is enabled, AWS Auto
     * Scaling creates target tracking scaling policies based on the specified target tracking configurations.
     * </p>
     * <p>
     * The default is enabled (<code>false</code>).
     * </p>
     * 
     * @param disableDynamicScaling
     *        Controls whether dynamic scaling by AWS Auto Scaling is disabled. When dynamic scaling is enabled, AWS
     *        Auto Scaling creates target tracking scaling policies based on the specified target tracking
     *        configurations. </p>
     *        <p>
     *        The default is enabled (<code>false</code>).
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public ScalingInstruction withDisableDynamicScaling(Boolean disableDynamicScaling) {
        setDisableDynamicScaling(disableDynamicScaling);
        return this;
    }

    /**
     * <p>
     * Controls whether dynamic scaling by AWS Auto Scaling is disabled. When dynamic scaling is enabled, AWS Auto
     * Scaling creates target tracking scaling policies based on the specified target tracking configurations.
     * </p>
     * <p>
     * The default is enabled (<code>false</code>).
     * </p>
     * 
     * @return Controls whether dynamic scaling by AWS Auto Scaling is disabled. When dynamic scaling is enabled, AWS
     *         Auto Scaling creates target tracking scaling policies based on the specified target tracking
     *         configurations. </p>
     *         <p>
     *         The default is enabled (<code>false</code>).
     */

    public Boolean isDisableDynamicScaling() {
        return this.disableDynamicScaling;
    }

    /**
     * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be
     * redacted from this string using a placeholder value.
     *
     * @return A string representation of this object.
     *
     * @see java.lang.Object#toString()
     */
    @Override
    public String toString() {
        StringBuilder sb = new StringBuilder();
        sb.append("{");
        if (getServiceNamespace() != null)
            sb.append("ServiceNamespace: ").append(getServiceNamespace()).append(",");
        if (getResourceId() != null)
            sb.append("ResourceId: ").append(getResourceId()).append(",");
        if (getScalableDimension() != null)
            sb.append("ScalableDimension: ").append(getScalableDimension()).append(",");
        if (getMinCapacity() != null)
            sb.append("MinCapacity: ").append(getMinCapacity()).append(",");
        if (getMaxCapacity() != null)
            sb.append("MaxCapacity: ").append(getMaxCapacity()).append(",");
        if (getTargetTrackingConfigurations() != null)
            sb.append("TargetTrackingConfigurations: ").append(getTargetTrackingConfigurations()).append(",");
        if (getPredefinedLoadMetricSpecification() != null)
            sb.append("PredefinedLoadMetricSpecification: ").append(getPredefinedLoadMetricSpecification()).append(",");
        if (getCustomizedLoadMetricSpecification() != null)
            sb.append("CustomizedLoadMetricSpecification: ").append(getCustomizedLoadMetricSpecification()).append(",");
        if (getScheduledActionBufferTime() != null)
            sb.append("ScheduledActionBufferTime: ").append(getScheduledActionBufferTime()).append(",");
        if (getPredictiveScalingMaxCapacityBehavior() != null)
            sb.append("PredictiveScalingMaxCapacityBehavior: ").append(getPredictiveScalingMaxCapacityBehavior()).append(",");
        if (getPredictiveScalingMaxCapacityBuffer() != null)
            sb.append("PredictiveScalingMaxCapacityBuffer: ").append(getPredictiveScalingMaxCapacityBuffer()).append(",");
        if (getPredictiveScalingMode() != null)
            sb.append("PredictiveScalingMode: ").append(getPredictiveScalingMode()).append(",");
        if (getScalingPolicyUpdateBehavior() != null)
            sb.append("ScalingPolicyUpdateBehavior: ").append(getScalingPolicyUpdateBehavior()).append(",");
        if (getDisableDynamicScaling() != null)
            sb.append("DisableDynamicScaling: ").append(getDisableDynamicScaling());
        sb.append("}");
        return sb.toString();
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;

        if (obj instanceof ScalingInstruction == false)
            return false;
        ScalingInstruction other = (ScalingInstruction) obj;
        if (other.getServiceNamespace() == null ^ this.getServiceNamespace() == null)
            return false;
        if (other.getServiceNamespace() != null && other.getServiceNamespace().equals(this.getServiceNamespace()) == false)
            return false;
        if (other.getResourceId() == null ^ this.getResourceId() == null)
            return false;
        if (other.getResourceId() != null && other.getResourceId().equals(this.getResourceId()) == false)
            return false;
        if (other.getScalableDimension() == null ^ this.getScalableDimension() == null)
            return false;
        if (other.getScalableDimension() != null && other.getScalableDimension().equals(this.getScalableDimension()) == false)
            return false;
        if (other.getMinCapacity() == null ^ this.getMinCapacity() == null)
            return false;
        if (other.getMinCapacity() != null && other.getMinCapacity().equals(this.getMinCapacity()) == false)
            return false;
        if (other.getMaxCapacity() == null ^ this.getMaxCapacity() == null)
            return false;
        if (other.getMaxCapacity() != null && other.getMaxCapacity().equals(this.getMaxCapacity()) == false)
            return false;
        if (other.getTargetTrackingConfigurations() == null ^ this.getTargetTrackingConfigurations() == null)
            return false;
        if (other.getTargetTrackingConfigurations() != null && other.getTargetTrackingConfigurations().equals(this.getTargetTrackingConfigurations()) == false)
            return false;
        if (other.getPredefinedLoadMetricSpecification() == null ^ this.getPredefinedLoadMetricSpecification() == null)
            return false;
        if (other.getPredefinedLoadMetricSpecification() != null
                && other.getPredefinedLoadMetricSpecification().equals(this.getPredefinedLoadMetricSpecification()) == false)
            return false;
        if (other.getCustomizedLoadMetricSpecification() == null ^ this.getCustomizedLoadMetricSpecification() == null)
            return false;
        if (other.getCustomizedLoadMetricSpecification() != null
                && other.getCustomizedLoadMetricSpecification().equals(this.getCustomizedLoadMetricSpecification()) == false)
            return false;
        if (other.getScheduledActionBufferTime() == null ^ this.getScheduledActionBufferTime() == null)
            return false;
        if (other.getScheduledActionBufferTime() != null && other.getScheduledActionBufferTime().equals(this.getScheduledActionBufferTime()) == false)
            return false;
        if (other.getPredictiveScalingMaxCapacityBehavior() == null ^ this.getPredictiveScalingMaxCapacityBehavior() == null)
            return false;
        if (other.getPredictiveScalingMaxCapacityBehavior() != null
                && other.getPredictiveScalingMaxCapacityBehavior().equals(this.getPredictiveScalingMaxCapacityBehavior()) == false)
            return false;
        if (other.getPredictiveScalingMaxCapacityBuffer() == null ^ this.getPredictiveScalingMaxCapacityBuffer() == null)
            return false;
        if (other.getPredictiveScalingMaxCapacityBuffer() != null
                && other.getPredictiveScalingMaxCapacityBuffer().equals(this.getPredictiveScalingMaxCapacityBuffer()) == false)
            return false;
        if (other.getPredictiveScalingMode() == null ^ this.getPredictiveScalingMode() == null)
            return false;
        if (other.getPredictiveScalingMode() != null && other.getPredictiveScalingMode().equals(this.getPredictiveScalingMode()) == false)
            return false;
        if (other.getScalingPolicyUpdateBehavior() == null ^ this.getScalingPolicyUpdateBehavior() == null)
            return false;
        if (other.getScalingPolicyUpdateBehavior() != null && other.getScalingPolicyUpdateBehavior().equals(this.getScalingPolicyUpdateBehavior()) == false)
            return false;
        if (other.getDisableDynamicScaling() == null ^ this.getDisableDynamicScaling() == null)
            return false;
        if (other.getDisableDynamicScaling() != null && other.getDisableDynamicScaling().equals(this.getDisableDynamicScaling()) == false)
            return false;
        return true;
    }

    @Override
    public int hashCode() {
        final int prime = 31;
        int hashCode = 1;

        hashCode = prime * hashCode + ((getServiceNamespace() == null) ? 0 : getServiceNamespace().hashCode());
        hashCode = prime * hashCode + ((getResourceId() == null) ? 0 : getResourceId().hashCode());
        hashCode = prime * hashCode + ((getScalableDimension() == null) ? 0 : getScalableDimension().hashCode());
        hashCode = prime * hashCode + ((getMinCapacity() == null) ? 0 : getMinCapacity().hashCode());
        hashCode = prime * hashCode + ((getMaxCapacity() == null) ? 0 : getMaxCapacity().hashCode());
        hashCode = prime * hashCode + ((getTargetTrackingConfigurations() == null) ? 0 : getTargetTrackingConfigurations().hashCode());
        hashCode = prime * hashCode + ((getPredefinedLoadMetricSpecification() == null) ? 0 : getPredefinedLoadMetricSpecification().hashCode());
        hashCode = prime * hashCode + ((getCustomizedLoadMetricSpecification() == null) ? 0 : getCustomizedLoadMetricSpecification().hashCode());
        hashCode = prime * hashCode + ((getScheduledActionBufferTime() == null) ? 0 : getScheduledActionBufferTime().hashCode());
        hashCode = prime * hashCode + ((getPredictiveScalingMaxCapacityBehavior() == null) ? 0 : getPredictiveScalingMaxCapacityBehavior().hashCode());
        hashCode = prime * hashCode + ((getPredictiveScalingMaxCapacityBuffer() == null) ? 0 : getPredictiveScalingMaxCapacityBuffer().hashCode());
        hashCode = prime * hashCode + ((getPredictiveScalingMode() == null) ? 0 : getPredictiveScalingMode().hashCode());
        hashCode = prime * hashCode + ((getScalingPolicyUpdateBehavior() == null) ? 0 : getScalingPolicyUpdateBehavior().hashCode());
        hashCode = prime * hashCode + ((getDisableDynamicScaling() == null) ? 0 : getDisableDynamicScaling().hashCode());
        return hashCode;
    }

    @Override
    public ScalingInstruction clone() {
        try {
            return (ScalingInstruction) super.clone();
        } catch (CloneNotSupportedException e) {
            throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e);
        }
    }

    @com.amazonaws.annotation.SdkInternalApi
    @Override
    public void marshall(ProtocolMarshaller protocolMarshaller) {
        com.amazonaws.services.autoscalingplans.model.transform.ScalingInstructionMarshaller.getInstance().marshall(this, protocolMarshaller);
    }
}