This repository has been archived on 2025-09-14. You can view files and clone it, but cannot push or open issues or pull requests.
Files

873 lines
56 KiB
C++

/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
* SPDX-License-Identifier: Apache-2.0.
*/
#pragma once
#include <aws/application-autoscaling/ApplicationAutoScaling_EXPORTS.h>
#include <aws/application-autoscaling/ApplicationAutoScalingRequest.h>
#include <aws/core/utils/memory/stl/AWSString.h>
#include <aws/application-autoscaling/model/ServiceNamespace.h>
#include <aws/application-autoscaling/model/ScalableDimension.h>
#include <aws/application-autoscaling/model/PolicyType.h>
#include <aws/application-autoscaling/model/StepScalingPolicyConfiguration.h>
#include <aws/application-autoscaling/model/TargetTrackingScalingPolicyConfiguration.h>
#include <utility>
namespace Aws
{
namespace ApplicationAutoScaling
{
namespace Model
{
/**
*/
class AWS_APPLICATIONAUTOSCALING_API PutScalingPolicyRequest : public ApplicationAutoScalingRequest
{
public:
PutScalingPolicyRequest();
// Service request name is the Operation name which will send this request out,
// each operation should has unique request name, so that we can get operation's name from this request.
// Note: this is not true for response, multiple operations may have the same response name,
// so we can not get operation's name from response.
inline virtual const char* GetServiceRequestName() const override { return "PutScalingPolicy"; }
Aws::String SerializePayload() const override;
Aws::Http::HeaderValueCollection GetRequestSpecificHeaders() const override;
/**
* <p>The name of the scaling policy.</p>
*/
inline const Aws::String& GetPolicyName() const{ return m_policyName; }
/**
* <p>The name of the scaling policy.</p>
*/
inline bool PolicyNameHasBeenSet() const { return m_policyNameHasBeenSet; }
/**
* <p>The name of the scaling policy.</p>
*/
inline void SetPolicyName(const Aws::String& value) { m_policyNameHasBeenSet = true; m_policyName = value; }
/**
* <p>The name of the scaling policy.</p>
*/
inline void SetPolicyName(Aws::String&& value) { m_policyNameHasBeenSet = true; m_policyName = std::move(value); }
/**
* <p>The name of the scaling policy.</p>
*/
inline void SetPolicyName(const char* value) { m_policyNameHasBeenSet = true; m_policyName.assign(value); }
/**
* <p>The name of the scaling policy.</p>
*/
inline PutScalingPolicyRequest& WithPolicyName(const Aws::String& value) { SetPolicyName(value); return *this;}
/**
* <p>The name of the scaling policy.</p>
*/
inline PutScalingPolicyRequest& WithPolicyName(Aws::String&& value) { SetPolicyName(std::move(value)); return *this;}
/**
* <p>The name of the scaling policy.</p>
*/
inline PutScalingPolicyRequest& WithPolicyName(const char* value) { SetPolicyName(value); return *this;}
/**
* <p>The namespace of the AWS service that provides the resource. For a resource
* provided by your own application or service, use <code>custom-resource</code>
* instead.</p>
*/
inline const ServiceNamespace& GetServiceNamespace() const{ return m_serviceNamespace; }
/**
* <p>The namespace of the AWS service that provides the resource. For a resource
* provided by your own application or service, use <code>custom-resource</code>
* instead.</p>
*/
inline bool ServiceNamespaceHasBeenSet() const { return m_serviceNamespaceHasBeenSet; }
/**
* <p>The namespace of the AWS service that provides the resource. For a resource
* provided by your own application or service, use <code>custom-resource</code>
* instead.</p>
*/
inline void SetServiceNamespace(const ServiceNamespace& value) { m_serviceNamespaceHasBeenSet = true; m_serviceNamespace = value; }
/**
* <p>The namespace of the AWS service that provides the resource. For a resource
* provided by your own application or service, use <code>custom-resource</code>
* instead.</p>
*/
inline void SetServiceNamespace(ServiceNamespace&& value) { m_serviceNamespaceHasBeenSet = true; m_serviceNamespace = std::move(value); }
/**
* <p>The namespace of the AWS service that provides the resource. For a resource
* provided by your own application or service, use <code>custom-resource</code>
* instead.</p>
*/
inline PutScalingPolicyRequest& WithServiceNamespace(const ServiceNamespace& value) { SetServiceNamespace(value); return *this;}
/**
* <p>The namespace of the AWS service that provides the resource. For a resource
* provided by your own application or service, use <code>custom-resource</code>
* instead.</p>
*/
inline PutScalingPolicyRequest& WithServiceNamespace(ServiceNamespace&& value) { SetServiceNamespace(std::move(value)); return *this;}
/**
* <p>The identifier of the resource associated with the scaling policy. This
* string consists of the resource type and unique identifier.</p> <ul> <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>EMR cluster - The resource type is <code>instancegroup</code> and
* the unique identifier is the cluster ID and instance group ID. Example:
* <code>instancegroup/j-2EEZNYKUA1NTV/ig-1791Y4E1L8YI0</code>.</p> </li> <li>
* <p>AppStream 2.0 fleet - The resource type is <code>fleet</code> and the unique
* identifier is the fleet name. Example: <code>fleet/sample-fleet</code>.</p>
* </li> <li> <p>DynamoDB table - The resource type is <code>table</code> and the
* unique identifier is the table name. 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 index name. 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> <li>
* <p>Amazon SageMaker endpoint variant - The resource type is <code>variant</code>
* and the unique identifier is the resource ID. Example:
* <code>endpoint/my-end-point/variant/KMeansClustering</code>.</p> </li> <li>
* <p>Custom resources are not supported with a resource type. This parameter must
* specify the <code>OutputValue</code> from the CloudFormation template stack used
* to access the resources. The unique identifier is defined by the service
* provider. More information is available in our <a
* href="https://github.com/aws/aws-auto-scaling-custom-resource">GitHub
* repository</a>.</p> </li> <li> <p>Amazon Comprehend document classification
* endpoint - The resource type and unique identifier are specified using the
* endpoint ARN. Example:
* <code>arn:aws:comprehend:us-west-2:123456789012:document-classifier-endpoint/EXAMPLE</code>.</p>
* </li> <li> <p>Lambda provisioned concurrency - The resource type is
* <code>function</code> and the unique identifier is the function name with a
* function version or alias name suffix that is not <code>$LATEST</code>. Example:
* <code>function:my-function:prod</code> or
* <code>function:my-function:1</code>.</p> </li> <li> <p>Amazon Keyspaces table -
* The resource type is <code>table</code> and the unique identifier is the table
* name. Example: <code>keyspace/mykeyspace/table/mytable</code>.</p> </li> </ul>
*/
inline const Aws::String& GetResourceId() const{ return m_resourceId; }
/**
* <p>The identifier of the resource associated with the scaling policy. This
* string consists of the resource type and unique identifier.</p> <ul> <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>EMR cluster - The resource type is <code>instancegroup</code> and
* the unique identifier is the cluster ID and instance group ID. Example:
* <code>instancegroup/j-2EEZNYKUA1NTV/ig-1791Y4E1L8YI0</code>.</p> </li> <li>
* <p>AppStream 2.0 fleet - The resource type is <code>fleet</code> and the unique
* identifier is the fleet name. Example: <code>fleet/sample-fleet</code>.</p>
* </li> <li> <p>DynamoDB table - The resource type is <code>table</code> and the
* unique identifier is the table name. 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 index name. 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> <li>
* <p>Amazon SageMaker endpoint variant - The resource type is <code>variant</code>
* and the unique identifier is the resource ID. Example:
* <code>endpoint/my-end-point/variant/KMeansClustering</code>.</p> </li> <li>
* <p>Custom resources are not supported with a resource type. This parameter must
* specify the <code>OutputValue</code> from the CloudFormation template stack used
* to access the resources. The unique identifier is defined by the service
* provider. More information is available in our <a
* href="https://github.com/aws/aws-auto-scaling-custom-resource">GitHub
* repository</a>.</p> </li> <li> <p>Amazon Comprehend document classification
* endpoint - The resource type and unique identifier are specified using the
* endpoint ARN. Example:
* <code>arn:aws:comprehend:us-west-2:123456789012:document-classifier-endpoint/EXAMPLE</code>.</p>
* </li> <li> <p>Lambda provisioned concurrency - The resource type is
* <code>function</code> and the unique identifier is the function name with a
* function version or alias name suffix that is not <code>$LATEST</code>. Example:
* <code>function:my-function:prod</code> or
* <code>function:my-function:1</code>.</p> </li> <li> <p>Amazon Keyspaces table -
* The resource type is <code>table</code> and the unique identifier is the table
* name. Example: <code>keyspace/mykeyspace/table/mytable</code>.</p> </li> </ul>
*/
inline bool ResourceIdHasBeenSet() const { return m_resourceIdHasBeenSet; }
/**
* <p>The identifier of the resource associated with the scaling policy. This
* string consists of the resource type and unique identifier.</p> <ul> <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>EMR cluster - The resource type is <code>instancegroup</code> and
* the unique identifier is the cluster ID and instance group ID. Example:
* <code>instancegroup/j-2EEZNYKUA1NTV/ig-1791Y4E1L8YI0</code>.</p> </li> <li>
* <p>AppStream 2.0 fleet - The resource type is <code>fleet</code> and the unique
* identifier is the fleet name. Example: <code>fleet/sample-fleet</code>.</p>
* </li> <li> <p>DynamoDB table - The resource type is <code>table</code> and the
* unique identifier is the table name. 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 index name. 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> <li>
* <p>Amazon SageMaker endpoint variant - The resource type is <code>variant</code>
* and the unique identifier is the resource ID. Example:
* <code>endpoint/my-end-point/variant/KMeansClustering</code>.</p> </li> <li>
* <p>Custom resources are not supported with a resource type. This parameter must
* specify the <code>OutputValue</code> from the CloudFormation template stack used
* to access the resources. The unique identifier is defined by the service
* provider. More information is available in our <a
* href="https://github.com/aws/aws-auto-scaling-custom-resource">GitHub
* repository</a>.</p> </li> <li> <p>Amazon Comprehend document classification
* endpoint - The resource type and unique identifier are specified using the
* endpoint ARN. Example:
* <code>arn:aws:comprehend:us-west-2:123456789012:document-classifier-endpoint/EXAMPLE</code>.</p>
* </li> <li> <p>Lambda provisioned concurrency - The resource type is
* <code>function</code> and the unique identifier is the function name with a
* function version or alias name suffix that is not <code>$LATEST</code>. Example:
* <code>function:my-function:prod</code> or
* <code>function:my-function:1</code>.</p> </li> <li> <p>Amazon Keyspaces table -
* The resource type is <code>table</code> and the unique identifier is the table
* name. Example: <code>keyspace/mykeyspace/table/mytable</code>.</p> </li> </ul>
*/
inline void SetResourceId(const Aws::String& value) { m_resourceIdHasBeenSet = true; m_resourceId = value; }
/**
* <p>The identifier of the resource associated with the scaling policy. This
* string consists of the resource type and unique identifier.</p> <ul> <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>EMR cluster - The resource type is <code>instancegroup</code> and
* the unique identifier is the cluster ID and instance group ID. Example:
* <code>instancegroup/j-2EEZNYKUA1NTV/ig-1791Y4E1L8YI0</code>.</p> </li> <li>
* <p>AppStream 2.0 fleet - The resource type is <code>fleet</code> and the unique
* identifier is the fleet name. Example: <code>fleet/sample-fleet</code>.</p>
* </li> <li> <p>DynamoDB table - The resource type is <code>table</code> and the
* unique identifier is the table name. 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 index name. 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> <li>
* <p>Amazon SageMaker endpoint variant - The resource type is <code>variant</code>
* and the unique identifier is the resource ID. Example:
* <code>endpoint/my-end-point/variant/KMeansClustering</code>.</p> </li> <li>
* <p>Custom resources are not supported with a resource type. This parameter must
* specify the <code>OutputValue</code> from the CloudFormation template stack used
* to access the resources. The unique identifier is defined by the service
* provider. More information is available in our <a
* href="https://github.com/aws/aws-auto-scaling-custom-resource">GitHub
* repository</a>.</p> </li> <li> <p>Amazon Comprehend document classification
* endpoint - The resource type and unique identifier are specified using the
* endpoint ARN. Example:
* <code>arn:aws:comprehend:us-west-2:123456789012:document-classifier-endpoint/EXAMPLE</code>.</p>
* </li> <li> <p>Lambda provisioned concurrency - The resource type is
* <code>function</code> and the unique identifier is the function name with a
* function version or alias name suffix that is not <code>$LATEST</code>. Example:
* <code>function:my-function:prod</code> or
* <code>function:my-function:1</code>.</p> </li> <li> <p>Amazon Keyspaces table -
* The resource type is <code>table</code> and the unique identifier is the table
* name. Example: <code>keyspace/mykeyspace/table/mytable</code>.</p> </li> </ul>
*/
inline void SetResourceId(Aws::String&& value) { m_resourceIdHasBeenSet = true; m_resourceId = std::move(value); }
/**
* <p>The identifier of the resource associated with the scaling policy. This
* string consists of the resource type and unique identifier.</p> <ul> <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>EMR cluster - The resource type is <code>instancegroup</code> and
* the unique identifier is the cluster ID and instance group ID. Example:
* <code>instancegroup/j-2EEZNYKUA1NTV/ig-1791Y4E1L8YI0</code>.</p> </li> <li>
* <p>AppStream 2.0 fleet - The resource type is <code>fleet</code> and the unique
* identifier is the fleet name. Example: <code>fleet/sample-fleet</code>.</p>
* </li> <li> <p>DynamoDB table - The resource type is <code>table</code> and the
* unique identifier is the table name. 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 index name. 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> <li>
* <p>Amazon SageMaker endpoint variant - The resource type is <code>variant</code>
* and the unique identifier is the resource ID. Example:
* <code>endpoint/my-end-point/variant/KMeansClustering</code>.</p> </li> <li>
* <p>Custom resources are not supported with a resource type. This parameter must
* specify the <code>OutputValue</code> from the CloudFormation template stack used
* to access the resources. The unique identifier is defined by the service
* provider. More information is available in our <a
* href="https://github.com/aws/aws-auto-scaling-custom-resource">GitHub
* repository</a>.</p> </li> <li> <p>Amazon Comprehend document classification
* endpoint - The resource type and unique identifier are specified using the
* endpoint ARN. Example:
* <code>arn:aws:comprehend:us-west-2:123456789012:document-classifier-endpoint/EXAMPLE</code>.</p>
* </li> <li> <p>Lambda provisioned concurrency - The resource type is
* <code>function</code> and the unique identifier is the function name with a
* function version or alias name suffix that is not <code>$LATEST</code>. Example:
* <code>function:my-function:prod</code> or
* <code>function:my-function:1</code>.</p> </li> <li> <p>Amazon Keyspaces table -
* The resource type is <code>table</code> and the unique identifier is the table
* name. Example: <code>keyspace/mykeyspace/table/mytable</code>.</p> </li> </ul>
*/
inline void SetResourceId(const char* value) { m_resourceIdHasBeenSet = true; m_resourceId.assign(value); }
/**
* <p>The identifier of the resource associated with the scaling policy. This
* string consists of the resource type and unique identifier.</p> <ul> <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>EMR cluster - The resource type is <code>instancegroup</code> and
* the unique identifier is the cluster ID and instance group ID. Example:
* <code>instancegroup/j-2EEZNYKUA1NTV/ig-1791Y4E1L8YI0</code>.</p> </li> <li>
* <p>AppStream 2.0 fleet - The resource type is <code>fleet</code> and the unique
* identifier is the fleet name. Example: <code>fleet/sample-fleet</code>.</p>
* </li> <li> <p>DynamoDB table - The resource type is <code>table</code> and the
* unique identifier is the table name. 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 index name. 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> <li>
* <p>Amazon SageMaker endpoint variant - The resource type is <code>variant</code>
* and the unique identifier is the resource ID. Example:
* <code>endpoint/my-end-point/variant/KMeansClustering</code>.</p> </li> <li>
* <p>Custom resources are not supported with a resource type. This parameter must
* specify the <code>OutputValue</code> from the CloudFormation template stack used
* to access the resources. The unique identifier is defined by the service
* provider. More information is available in our <a
* href="https://github.com/aws/aws-auto-scaling-custom-resource">GitHub
* repository</a>.</p> </li> <li> <p>Amazon Comprehend document classification
* endpoint - The resource type and unique identifier are specified using the
* endpoint ARN. Example:
* <code>arn:aws:comprehend:us-west-2:123456789012:document-classifier-endpoint/EXAMPLE</code>.</p>
* </li> <li> <p>Lambda provisioned concurrency - The resource type is
* <code>function</code> and the unique identifier is the function name with a
* function version or alias name suffix that is not <code>$LATEST</code>. Example:
* <code>function:my-function:prod</code> or
* <code>function:my-function:1</code>.</p> </li> <li> <p>Amazon Keyspaces table -
* The resource type is <code>table</code> and the unique identifier is the table
* name. Example: <code>keyspace/mykeyspace/table/mytable</code>.</p> </li> </ul>
*/
inline PutScalingPolicyRequest& WithResourceId(const Aws::String& value) { SetResourceId(value); return *this;}
/**
* <p>The identifier of the resource associated with the scaling policy. This
* string consists of the resource type and unique identifier.</p> <ul> <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>EMR cluster - The resource type is <code>instancegroup</code> and
* the unique identifier is the cluster ID and instance group ID. Example:
* <code>instancegroup/j-2EEZNYKUA1NTV/ig-1791Y4E1L8YI0</code>.</p> </li> <li>
* <p>AppStream 2.0 fleet - The resource type is <code>fleet</code> and the unique
* identifier is the fleet name. Example: <code>fleet/sample-fleet</code>.</p>
* </li> <li> <p>DynamoDB table - The resource type is <code>table</code> and the
* unique identifier is the table name. 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 index name. 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> <li>
* <p>Amazon SageMaker endpoint variant - The resource type is <code>variant</code>
* and the unique identifier is the resource ID. Example:
* <code>endpoint/my-end-point/variant/KMeansClustering</code>.</p> </li> <li>
* <p>Custom resources are not supported with a resource type. This parameter must
* specify the <code>OutputValue</code> from the CloudFormation template stack used
* to access the resources. The unique identifier is defined by the service
* provider. More information is available in our <a
* href="https://github.com/aws/aws-auto-scaling-custom-resource">GitHub
* repository</a>.</p> </li> <li> <p>Amazon Comprehend document classification
* endpoint - The resource type and unique identifier are specified using the
* endpoint ARN. Example:
* <code>arn:aws:comprehend:us-west-2:123456789012:document-classifier-endpoint/EXAMPLE</code>.</p>
* </li> <li> <p>Lambda provisioned concurrency - The resource type is
* <code>function</code> and the unique identifier is the function name with a
* function version or alias name suffix that is not <code>$LATEST</code>. Example:
* <code>function:my-function:prod</code> or
* <code>function:my-function:1</code>.</p> </li> <li> <p>Amazon Keyspaces table -
* The resource type is <code>table</code> and the unique identifier is the table
* name. Example: <code>keyspace/mykeyspace/table/mytable</code>.</p> </li> </ul>
*/
inline PutScalingPolicyRequest& WithResourceId(Aws::String&& value) { SetResourceId(std::move(value)); return *this;}
/**
* <p>The identifier of the resource associated with the scaling policy. This
* string consists of the resource type and unique identifier.</p> <ul> <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>EMR cluster - The resource type is <code>instancegroup</code> and
* the unique identifier is the cluster ID and instance group ID. Example:
* <code>instancegroup/j-2EEZNYKUA1NTV/ig-1791Y4E1L8YI0</code>.</p> </li> <li>
* <p>AppStream 2.0 fleet - The resource type is <code>fleet</code> and the unique
* identifier is the fleet name. Example: <code>fleet/sample-fleet</code>.</p>
* </li> <li> <p>DynamoDB table - The resource type is <code>table</code> and the
* unique identifier is the table name. 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 index name. 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> <li>
* <p>Amazon SageMaker endpoint variant - The resource type is <code>variant</code>
* and the unique identifier is the resource ID. Example:
* <code>endpoint/my-end-point/variant/KMeansClustering</code>.</p> </li> <li>
* <p>Custom resources are not supported with a resource type. This parameter must
* specify the <code>OutputValue</code> from the CloudFormation template stack used
* to access the resources. The unique identifier is defined by the service
* provider. More information is available in our <a
* href="https://github.com/aws/aws-auto-scaling-custom-resource">GitHub
* repository</a>.</p> </li> <li> <p>Amazon Comprehend document classification
* endpoint - The resource type and unique identifier are specified using the
* endpoint ARN. Example:
* <code>arn:aws:comprehend:us-west-2:123456789012:document-classifier-endpoint/EXAMPLE</code>.</p>
* </li> <li> <p>Lambda provisioned concurrency - The resource type is
* <code>function</code> and the unique identifier is the function name with a
* function version or alias name suffix that is not <code>$LATEST</code>. Example:
* <code>function:my-function:prod</code> or
* <code>function:my-function:1</code>.</p> </li> <li> <p>Amazon Keyspaces table -
* The resource type is <code>table</code> and the unique identifier is the table
* name. Example: <code>keyspace/mykeyspace/table/mytable</code>.</p> </li> </ul>
*/
inline PutScalingPolicyRequest& WithResourceId(const char* value) { SetResourceId(value); return *this;}
/**
* <p>The scalable dimension. This string consists of the service namespace,
* resource type, and scaling property.</p> <ul> <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>elasticmapreduce:instancegroup:InstanceCount</code> - The instance count
* of an EMR Instance Group.</p> </li> <li> <p>
* <code>appstream:fleet:DesiredCapacity</code> - The desired capacity of an
* AppStream 2.0 fleet.</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> <li> <p>
* <code>sagemaker:variant:DesiredInstanceCount</code> - The number of EC2
* instances for an Amazon SageMaker model endpoint variant.</p> </li> <li> <p>
* <code>custom-resource:ResourceType:Property</code> - The scalable dimension for
* a custom resource provided by your own application or service.</p> </li> <li>
* <p> <code>comprehend:document-classifier-endpoint:DesiredInferenceUnits</code> -
* The number of inference units for an Amazon Comprehend document classification
* endpoint.</p> </li> <li> <p> <code>lambda:function:ProvisionedConcurrency</code>
* - The provisioned concurrency for a Lambda function.</p> </li> <li> <p>
* <code>cassandra:table:ReadCapacityUnits</code> - The provisioned read capacity
* for an Amazon Keyspaces table.</p> </li> <li> <p>
* <code>cassandra:table:WriteCapacityUnits</code> - The provisioned write capacity
* for an Amazon Keyspaces table.</p> </li> </ul>
*/
inline const ScalableDimension& GetScalableDimension() const{ return m_scalableDimension; }
/**
* <p>The scalable dimension. This string consists of the service namespace,
* resource type, and scaling property.</p> <ul> <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>elasticmapreduce:instancegroup:InstanceCount</code> - The instance count
* of an EMR Instance Group.</p> </li> <li> <p>
* <code>appstream:fleet:DesiredCapacity</code> - The desired capacity of an
* AppStream 2.0 fleet.</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> <li> <p>
* <code>sagemaker:variant:DesiredInstanceCount</code> - The number of EC2
* instances for an Amazon SageMaker model endpoint variant.</p> </li> <li> <p>
* <code>custom-resource:ResourceType:Property</code> - The scalable dimension for
* a custom resource provided by your own application or service.</p> </li> <li>
* <p> <code>comprehend:document-classifier-endpoint:DesiredInferenceUnits</code> -
* The number of inference units for an Amazon Comprehend document classification
* endpoint.</p> </li> <li> <p> <code>lambda:function:ProvisionedConcurrency</code>
* - The provisioned concurrency for a Lambda function.</p> </li> <li> <p>
* <code>cassandra:table:ReadCapacityUnits</code> - The provisioned read capacity
* for an Amazon Keyspaces table.</p> </li> <li> <p>
* <code>cassandra:table:WriteCapacityUnits</code> - The provisioned write capacity
* for an Amazon Keyspaces table.</p> </li> </ul>
*/
inline bool ScalableDimensionHasBeenSet() const { return m_scalableDimensionHasBeenSet; }
/**
* <p>The scalable dimension. This string consists of the service namespace,
* resource type, and scaling property.</p> <ul> <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>elasticmapreduce:instancegroup:InstanceCount</code> - The instance count
* of an EMR Instance Group.</p> </li> <li> <p>
* <code>appstream:fleet:DesiredCapacity</code> - The desired capacity of an
* AppStream 2.0 fleet.</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> <li> <p>
* <code>sagemaker:variant:DesiredInstanceCount</code> - The number of EC2
* instances for an Amazon SageMaker model endpoint variant.</p> </li> <li> <p>
* <code>custom-resource:ResourceType:Property</code> - The scalable dimension for
* a custom resource provided by your own application or service.</p> </li> <li>
* <p> <code>comprehend:document-classifier-endpoint:DesiredInferenceUnits</code> -
* The number of inference units for an Amazon Comprehend document classification
* endpoint.</p> </li> <li> <p> <code>lambda:function:ProvisionedConcurrency</code>
* - The provisioned concurrency for a Lambda function.</p> </li> <li> <p>
* <code>cassandra:table:ReadCapacityUnits</code> - The provisioned read capacity
* for an Amazon Keyspaces table.</p> </li> <li> <p>
* <code>cassandra:table:WriteCapacityUnits</code> - The provisioned write capacity
* for an Amazon Keyspaces table.</p> </li> </ul>
*/
inline void SetScalableDimension(const ScalableDimension& value) { m_scalableDimensionHasBeenSet = true; m_scalableDimension = value; }
/**
* <p>The scalable dimension. This string consists of the service namespace,
* resource type, and scaling property.</p> <ul> <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>elasticmapreduce:instancegroup:InstanceCount</code> - The instance count
* of an EMR Instance Group.</p> </li> <li> <p>
* <code>appstream:fleet:DesiredCapacity</code> - The desired capacity of an
* AppStream 2.0 fleet.</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> <li> <p>
* <code>sagemaker:variant:DesiredInstanceCount</code> - The number of EC2
* instances for an Amazon SageMaker model endpoint variant.</p> </li> <li> <p>
* <code>custom-resource:ResourceType:Property</code> - The scalable dimension for
* a custom resource provided by your own application or service.</p> </li> <li>
* <p> <code>comprehend:document-classifier-endpoint:DesiredInferenceUnits</code> -
* The number of inference units for an Amazon Comprehend document classification
* endpoint.</p> </li> <li> <p> <code>lambda:function:ProvisionedConcurrency</code>
* - The provisioned concurrency for a Lambda function.</p> </li> <li> <p>
* <code>cassandra:table:ReadCapacityUnits</code> - The provisioned read capacity
* for an Amazon Keyspaces table.</p> </li> <li> <p>
* <code>cassandra:table:WriteCapacityUnits</code> - The provisioned write capacity
* for an Amazon Keyspaces table.</p> </li> </ul>
*/
inline void SetScalableDimension(ScalableDimension&& value) { m_scalableDimensionHasBeenSet = true; m_scalableDimension = std::move(value); }
/**
* <p>The scalable dimension. This string consists of the service namespace,
* resource type, and scaling property.</p> <ul> <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>elasticmapreduce:instancegroup:InstanceCount</code> - The instance count
* of an EMR Instance Group.</p> </li> <li> <p>
* <code>appstream:fleet:DesiredCapacity</code> - The desired capacity of an
* AppStream 2.0 fleet.</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> <li> <p>
* <code>sagemaker:variant:DesiredInstanceCount</code> - The number of EC2
* instances for an Amazon SageMaker model endpoint variant.</p> </li> <li> <p>
* <code>custom-resource:ResourceType:Property</code> - The scalable dimension for
* a custom resource provided by your own application or service.</p> </li> <li>
* <p> <code>comprehend:document-classifier-endpoint:DesiredInferenceUnits</code> -
* The number of inference units for an Amazon Comprehend document classification
* endpoint.</p> </li> <li> <p> <code>lambda:function:ProvisionedConcurrency</code>
* - The provisioned concurrency for a Lambda function.</p> </li> <li> <p>
* <code>cassandra:table:ReadCapacityUnits</code> - The provisioned read capacity
* for an Amazon Keyspaces table.</p> </li> <li> <p>
* <code>cassandra:table:WriteCapacityUnits</code> - The provisioned write capacity
* for an Amazon Keyspaces table.</p> </li> </ul>
*/
inline PutScalingPolicyRequest& WithScalableDimension(const ScalableDimension& value) { SetScalableDimension(value); return *this;}
/**
* <p>The scalable dimension. This string consists of the service namespace,
* resource type, and scaling property.</p> <ul> <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>elasticmapreduce:instancegroup:InstanceCount</code> - The instance count
* of an EMR Instance Group.</p> </li> <li> <p>
* <code>appstream:fleet:DesiredCapacity</code> - The desired capacity of an
* AppStream 2.0 fleet.</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> <li> <p>
* <code>sagemaker:variant:DesiredInstanceCount</code> - The number of EC2
* instances for an Amazon SageMaker model endpoint variant.</p> </li> <li> <p>
* <code>custom-resource:ResourceType:Property</code> - The scalable dimension for
* a custom resource provided by your own application or service.</p> </li> <li>
* <p> <code>comprehend:document-classifier-endpoint:DesiredInferenceUnits</code> -
* The number of inference units for an Amazon Comprehend document classification
* endpoint.</p> </li> <li> <p> <code>lambda:function:ProvisionedConcurrency</code>
* - The provisioned concurrency for a Lambda function.</p> </li> <li> <p>
* <code>cassandra:table:ReadCapacityUnits</code> - The provisioned read capacity
* for an Amazon Keyspaces table.</p> </li> <li> <p>
* <code>cassandra:table:WriteCapacityUnits</code> - The provisioned write capacity
* for an Amazon Keyspaces table.</p> </li> </ul>
*/
inline PutScalingPolicyRequest& WithScalableDimension(ScalableDimension&& value) { SetScalableDimension(std::move(value)); return *this;}
/**
* <p>The policy type. This parameter is required if you are creating a scaling
* policy.</p> <p>The following policy types are supported: </p> <p>
* <code>TargetTrackingScaling</code>—Not supported for Amazon EMR</p> <p>
* <code>StepScaling</code>—Not supported for DynamoDB, Amazon Comprehend, Lambda,
* or Amazon Keyspaces (for Apache Cassandra).</p> <p>For more information, see <a
* href="https://docs.aws.amazon.com/autoscaling/application/userguide/application-auto-scaling-target-tracking.html">Target
* Tracking Scaling Policies</a> and <a
* href="https://docs.aws.amazon.com/autoscaling/application/userguide/application-auto-scaling-step-scaling-policies.html">Step
* Scaling Policies</a> in the <i>Application Auto Scaling User Guide</i>.</p>
*/
inline const PolicyType& GetPolicyType() const{ return m_policyType; }
/**
* <p>The policy type. This parameter is required if you are creating a scaling
* policy.</p> <p>The following policy types are supported: </p> <p>
* <code>TargetTrackingScaling</code>—Not supported for Amazon EMR</p> <p>
* <code>StepScaling</code>—Not supported for DynamoDB, Amazon Comprehend, Lambda,
* or Amazon Keyspaces (for Apache Cassandra).</p> <p>For more information, see <a
* href="https://docs.aws.amazon.com/autoscaling/application/userguide/application-auto-scaling-target-tracking.html">Target
* Tracking Scaling Policies</a> and <a
* href="https://docs.aws.amazon.com/autoscaling/application/userguide/application-auto-scaling-step-scaling-policies.html">Step
* Scaling Policies</a> in the <i>Application Auto Scaling User Guide</i>.</p>
*/
inline bool PolicyTypeHasBeenSet() const { return m_policyTypeHasBeenSet; }
/**
* <p>The policy type. This parameter is required if you are creating a scaling
* policy.</p> <p>The following policy types are supported: </p> <p>
* <code>TargetTrackingScaling</code>—Not supported for Amazon EMR</p> <p>
* <code>StepScaling</code>—Not supported for DynamoDB, Amazon Comprehend, Lambda,
* or Amazon Keyspaces (for Apache Cassandra).</p> <p>For more information, see <a
* href="https://docs.aws.amazon.com/autoscaling/application/userguide/application-auto-scaling-target-tracking.html">Target
* Tracking Scaling Policies</a> and <a
* href="https://docs.aws.amazon.com/autoscaling/application/userguide/application-auto-scaling-step-scaling-policies.html">Step
* Scaling Policies</a> in the <i>Application Auto Scaling User Guide</i>.</p>
*/
inline void SetPolicyType(const PolicyType& value) { m_policyTypeHasBeenSet = true; m_policyType = value; }
/**
* <p>The policy type. This parameter is required if you are creating a scaling
* policy.</p> <p>The following policy types are supported: </p> <p>
* <code>TargetTrackingScaling</code>—Not supported for Amazon EMR</p> <p>
* <code>StepScaling</code>—Not supported for DynamoDB, Amazon Comprehend, Lambda,
* or Amazon Keyspaces (for Apache Cassandra).</p> <p>For more information, see <a
* href="https://docs.aws.amazon.com/autoscaling/application/userguide/application-auto-scaling-target-tracking.html">Target
* Tracking Scaling Policies</a> and <a
* href="https://docs.aws.amazon.com/autoscaling/application/userguide/application-auto-scaling-step-scaling-policies.html">Step
* Scaling Policies</a> in the <i>Application Auto Scaling User Guide</i>.</p>
*/
inline void SetPolicyType(PolicyType&& value) { m_policyTypeHasBeenSet = true; m_policyType = std::move(value); }
/**
* <p>The policy type. This parameter is required if you are creating a scaling
* policy.</p> <p>The following policy types are supported: </p> <p>
* <code>TargetTrackingScaling</code>—Not supported for Amazon EMR</p> <p>
* <code>StepScaling</code>—Not supported for DynamoDB, Amazon Comprehend, Lambda,
* or Amazon Keyspaces (for Apache Cassandra).</p> <p>For more information, see <a
* href="https://docs.aws.amazon.com/autoscaling/application/userguide/application-auto-scaling-target-tracking.html">Target
* Tracking Scaling Policies</a> and <a
* href="https://docs.aws.amazon.com/autoscaling/application/userguide/application-auto-scaling-step-scaling-policies.html">Step
* Scaling Policies</a> in the <i>Application Auto Scaling User Guide</i>.</p>
*/
inline PutScalingPolicyRequest& WithPolicyType(const PolicyType& value) { SetPolicyType(value); return *this;}
/**
* <p>The policy type. This parameter is required if you are creating a scaling
* policy.</p> <p>The following policy types are supported: </p> <p>
* <code>TargetTrackingScaling</code>—Not supported for Amazon EMR</p> <p>
* <code>StepScaling</code>—Not supported for DynamoDB, Amazon Comprehend, Lambda,
* or Amazon Keyspaces (for Apache Cassandra).</p> <p>For more information, see <a
* href="https://docs.aws.amazon.com/autoscaling/application/userguide/application-auto-scaling-target-tracking.html">Target
* Tracking Scaling Policies</a> and <a
* href="https://docs.aws.amazon.com/autoscaling/application/userguide/application-auto-scaling-step-scaling-policies.html">Step
* Scaling Policies</a> in the <i>Application Auto Scaling User Guide</i>.</p>
*/
inline PutScalingPolicyRequest& WithPolicyType(PolicyType&& value) { SetPolicyType(std::move(value)); return *this;}
/**
* <p>A step scaling policy.</p> <p>This parameter is required if you are creating
* a policy and the policy type is <code>StepScaling</code>.</p>
*/
inline const StepScalingPolicyConfiguration& GetStepScalingPolicyConfiguration() const{ return m_stepScalingPolicyConfiguration; }
/**
* <p>A step scaling policy.</p> <p>This parameter is required if you are creating
* a policy and the policy type is <code>StepScaling</code>.</p>
*/
inline bool StepScalingPolicyConfigurationHasBeenSet() const { return m_stepScalingPolicyConfigurationHasBeenSet; }
/**
* <p>A step scaling policy.</p> <p>This parameter is required if you are creating
* a policy and the policy type is <code>StepScaling</code>.</p>
*/
inline void SetStepScalingPolicyConfiguration(const StepScalingPolicyConfiguration& value) { m_stepScalingPolicyConfigurationHasBeenSet = true; m_stepScalingPolicyConfiguration = value; }
/**
* <p>A step scaling policy.</p> <p>This parameter is required if you are creating
* a policy and the policy type is <code>StepScaling</code>.</p>
*/
inline void SetStepScalingPolicyConfiguration(StepScalingPolicyConfiguration&& value) { m_stepScalingPolicyConfigurationHasBeenSet = true; m_stepScalingPolicyConfiguration = std::move(value); }
/**
* <p>A step scaling policy.</p> <p>This parameter is required if you are creating
* a policy and the policy type is <code>StepScaling</code>.</p>
*/
inline PutScalingPolicyRequest& WithStepScalingPolicyConfiguration(const StepScalingPolicyConfiguration& value) { SetStepScalingPolicyConfiguration(value); return *this;}
/**
* <p>A step scaling policy.</p> <p>This parameter is required if you are creating
* a policy and the policy type is <code>StepScaling</code>.</p>
*/
inline PutScalingPolicyRequest& WithStepScalingPolicyConfiguration(StepScalingPolicyConfiguration&& value) { SetStepScalingPolicyConfiguration(std::move(value)); return *this;}
/**
* <p>A target tracking scaling policy. Includes support for predefined or
* customized metrics.</p> <p>This parameter is required if you are creating a
* policy and the policy type is <code>TargetTrackingScaling</code>.</p>
*/
inline const TargetTrackingScalingPolicyConfiguration& GetTargetTrackingScalingPolicyConfiguration() const{ return m_targetTrackingScalingPolicyConfiguration; }
/**
* <p>A target tracking scaling policy. Includes support for predefined or
* customized metrics.</p> <p>This parameter is required if you are creating a
* policy and the policy type is <code>TargetTrackingScaling</code>.</p>
*/
inline bool TargetTrackingScalingPolicyConfigurationHasBeenSet() const { return m_targetTrackingScalingPolicyConfigurationHasBeenSet; }
/**
* <p>A target tracking scaling policy. Includes support for predefined or
* customized metrics.</p> <p>This parameter is required if you are creating a
* policy and the policy type is <code>TargetTrackingScaling</code>.</p>
*/
inline void SetTargetTrackingScalingPolicyConfiguration(const TargetTrackingScalingPolicyConfiguration& value) { m_targetTrackingScalingPolicyConfigurationHasBeenSet = true; m_targetTrackingScalingPolicyConfiguration = value; }
/**
* <p>A target tracking scaling policy. Includes support for predefined or
* customized metrics.</p> <p>This parameter is required if you are creating a
* policy and the policy type is <code>TargetTrackingScaling</code>.</p>
*/
inline void SetTargetTrackingScalingPolicyConfiguration(TargetTrackingScalingPolicyConfiguration&& value) { m_targetTrackingScalingPolicyConfigurationHasBeenSet = true; m_targetTrackingScalingPolicyConfiguration = std::move(value); }
/**
* <p>A target tracking scaling policy. Includes support for predefined or
* customized metrics.</p> <p>This parameter is required if you are creating a
* policy and the policy type is <code>TargetTrackingScaling</code>.</p>
*/
inline PutScalingPolicyRequest& WithTargetTrackingScalingPolicyConfiguration(const TargetTrackingScalingPolicyConfiguration& value) { SetTargetTrackingScalingPolicyConfiguration(value); return *this;}
/**
* <p>A target tracking scaling policy. Includes support for predefined or
* customized metrics.</p> <p>This parameter is required if you are creating a
* policy and the policy type is <code>TargetTrackingScaling</code>.</p>
*/
inline PutScalingPolicyRequest& WithTargetTrackingScalingPolicyConfiguration(TargetTrackingScalingPolicyConfiguration&& value) { SetTargetTrackingScalingPolicyConfiguration(std::move(value)); return *this;}
private:
Aws::String m_policyName;
bool m_policyNameHasBeenSet;
ServiceNamespace m_serviceNamespace;
bool m_serviceNamespaceHasBeenSet;
Aws::String m_resourceId;
bool m_resourceIdHasBeenSet;
ScalableDimension m_scalableDimension;
bool m_scalableDimensionHasBeenSet;
PolicyType m_policyType;
bool m_policyTypeHasBeenSet;
StepScalingPolicyConfiguration m_stepScalingPolicyConfiguration;
bool m_stepScalingPolicyConfigurationHasBeenSet;
TargetTrackingScalingPolicyConfiguration m_targetTrackingScalingPolicyConfiguration;
bool m_targetTrackingScalingPolicyConfigurationHasBeenSet;
};
} // namespace Model
} // namespace ApplicationAutoScaling
} // namespace Aws