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

819 lines
49 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/model/ServiceNamespace.h>
#include <aws/core/utils/memory/stl/AWSString.h>
#include <aws/application-autoscaling/model/ScalableDimension.h>
#include <aws/core/utils/DateTime.h>
#include <aws/application-autoscaling/model/SuspendedState.h>
#include <utility>
namespace Aws
{
namespace Utils
{
namespace Json
{
class JsonValue;
class JsonView;
} // namespace Json
} // namespace Utils
namespace ApplicationAutoScaling
{
namespace Model
{
/**
* <p>Represents a scalable target.</p><p><h3>See Also:</h3> <a
* href="http://docs.aws.amazon.com/goto/WebAPI/application-autoscaling-2016-02-06/ScalableTarget">AWS
* API Reference</a></p>
*/
class AWS_APPLICATIONAUTOSCALING_API ScalableTarget
{
public:
ScalableTarget();
ScalableTarget(Aws::Utils::Json::JsonView jsonValue);
ScalableTarget& operator=(Aws::Utils::Json::JsonView jsonValue);
Aws::Utils::Json::JsonValue Jsonize() const;
/**
* <p>The namespace of the AWS service that provides the resource, or a
* <code>custom-resource</code>.</p>
*/
inline const ServiceNamespace& GetServiceNamespace() const{ return m_serviceNamespace; }
/**
* <p>The namespace of the AWS service that provides the resource, or a
* <code>custom-resource</code>.</p>
*/
inline bool ServiceNamespaceHasBeenSet() const { return m_serviceNamespaceHasBeenSet; }
/**
* <p>The namespace of the AWS service that provides the resource, or a
* <code>custom-resource</code>.</p>
*/
inline void SetServiceNamespace(const ServiceNamespace& value) { m_serviceNamespaceHasBeenSet = true; m_serviceNamespace = value; }
/**
* <p>The namespace of the AWS service that provides the resource, or a
* <code>custom-resource</code>.</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, or a
* <code>custom-resource</code>.</p>
*/
inline ScalableTarget& WithServiceNamespace(const ServiceNamespace& value) { SetServiceNamespace(value); return *this;}
/**
* <p>The namespace of the AWS service that provides the resource, or a
* <code>custom-resource</code>.</p>
*/
inline ScalableTarget& WithServiceNamespace(ServiceNamespace&& value) { SetServiceNamespace(std::move(value)); return *this;}
/**
* <p>The identifier of the resource associated with the scalable target. 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 scalable target. 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 scalable target. 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 scalable target. 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 scalable target. 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 scalable target. 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 ScalableTarget& WithResourceId(const Aws::String& value) { SetResourceId(value); return *this;}
/**
* <p>The identifier of the resource associated with the scalable target. 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 ScalableTarget& WithResourceId(Aws::String&& value) { SetResourceId(std::move(value)); return *this;}
/**
* <p>The identifier of the resource associated with the scalable target. 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 ScalableTarget& WithResourceId(const char* value) { SetResourceId(value); return *this;}
/**
* <p>The scalable dimension associated with the scalable target. 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 associated with the scalable target. 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 associated with the scalable target. 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 associated with the scalable target. 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 associated with the scalable target. 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 ScalableTarget& WithScalableDimension(const ScalableDimension& value) { SetScalableDimension(value); return *this;}
/**
* <p>The scalable dimension associated with the scalable target. 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 ScalableTarget& WithScalableDimension(ScalableDimension&& value) { SetScalableDimension(std::move(value)); return *this;}
/**
* <p>The minimum value to scale to in response to a scale-in activity.</p>
*/
inline int GetMinCapacity() const{ return m_minCapacity; }
/**
* <p>The minimum value to scale to in response to a scale-in activity.</p>
*/
inline bool MinCapacityHasBeenSet() const { return m_minCapacityHasBeenSet; }
/**
* <p>The minimum value to scale to in response to a scale-in activity.</p>
*/
inline void SetMinCapacity(int value) { m_minCapacityHasBeenSet = true; m_minCapacity = value; }
/**
* <p>The minimum value to scale to in response to a scale-in activity.</p>
*/
inline ScalableTarget& WithMinCapacity(int value) { SetMinCapacity(value); return *this;}
/**
* <p>The maximum value to scale to in response to a scale-out activity.</p>
*/
inline int GetMaxCapacity() const{ return m_maxCapacity; }
/**
* <p>The maximum value to scale to in response to a scale-out activity.</p>
*/
inline bool MaxCapacityHasBeenSet() const { return m_maxCapacityHasBeenSet; }
/**
* <p>The maximum value to scale to in response to a scale-out activity.</p>
*/
inline void SetMaxCapacity(int value) { m_maxCapacityHasBeenSet = true; m_maxCapacity = value; }
/**
* <p>The maximum value to scale to in response to a scale-out activity.</p>
*/
inline ScalableTarget& WithMaxCapacity(int value) { SetMaxCapacity(value); return *this;}
/**
* <p>The ARN of an IAM role that allows Application Auto Scaling to modify the
* scalable target on your behalf.</p>
*/
inline const Aws::String& GetRoleARN() const{ return m_roleARN; }
/**
* <p>The ARN of an IAM role that allows Application Auto Scaling to modify the
* scalable target on your behalf.</p>
*/
inline bool RoleARNHasBeenSet() const { return m_roleARNHasBeenSet; }
/**
* <p>The ARN of an IAM role that allows Application Auto Scaling to modify the
* scalable target on your behalf.</p>
*/
inline void SetRoleARN(const Aws::String& value) { m_roleARNHasBeenSet = true; m_roleARN = value; }
/**
* <p>The ARN of an IAM role that allows Application Auto Scaling to modify the
* scalable target on your behalf.</p>
*/
inline void SetRoleARN(Aws::String&& value) { m_roleARNHasBeenSet = true; m_roleARN = std::move(value); }
/**
* <p>The ARN of an IAM role that allows Application Auto Scaling to modify the
* scalable target on your behalf.</p>
*/
inline void SetRoleARN(const char* value) { m_roleARNHasBeenSet = true; m_roleARN.assign(value); }
/**
* <p>The ARN of an IAM role that allows Application Auto Scaling to modify the
* scalable target on your behalf.</p>
*/
inline ScalableTarget& WithRoleARN(const Aws::String& value) { SetRoleARN(value); return *this;}
/**
* <p>The ARN of an IAM role that allows Application Auto Scaling to modify the
* scalable target on your behalf.</p>
*/
inline ScalableTarget& WithRoleARN(Aws::String&& value) { SetRoleARN(std::move(value)); return *this;}
/**
* <p>The ARN of an IAM role that allows Application Auto Scaling to modify the
* scalable target on your behalf.</p>
*/
inline ScalableTarget& WithRoleARN(const char* value) { SetRoleARN(value); return *this;}
/**
* <p>The Unix timestamp for when the scalable target was created.</p>
*/
inline const Aws::Utils::DateTime& GetCreationTime() const{ return m_creationTime; }
/**
* <p>The Unix timestamp for when the scalable target was created.</p>
*/
inline bool CreationTimeHasBeenSet() const { return m_creationTimeHasBeenSet; }
/**
* <p>The Unix timestamp for when the scalable target was created.</p>
*/
inline void SetCreationTime(const Aws::Utils::DateTime& value) { m_creationTimeHasBeenSet = true; m_creationTime = value; }
/**
* <p>The Unix timestamp for when the scalable target was created.</p>
*/
inline void SetCreationTime(Aws::Utils::DateTime&& value) { m_creationTimeHasBeenSet = true; m_creationTime = std::move(value); }
/**
* <p>The Unix timestamp for when the scalable target was created.</p>
*/
inline ScalableTarget& WithCreationTime(const Aws::Utils::DateTime& value) { SetCreationTime(value); return *this;}
/**
* <p>The Unix timestamp for when the scalable target was created.</p>
*/
inline ScalableTarget& WithCreationTime(Aws::Utils::DateTime&& value) { SetCreationTime(std::move(value)); return *this;}
inline const SuspendedState& GetSuspendedState() const{ return m_suspendedState; }
inline bool SuspendedStateHasBeenSet() const { return m_suspendedStateHasBeenSet; }
inline void SetSuspendedState(const SuspendedState& value) { m_suspendedStateHasBeenSet = true; m_suspendedState = value; }
inline void SetSuspendedState(SuspendedState&& value) { m_suspendedStateHasBeenSet = true; m_suspendedState = std::move(value); }
inline ScalableTarget& WithSuspendedState(const SuspendedState& value) { SetSuspendedState(value); return *this;}
inline ScalableTarget& WithSuspendedState(SuspendedState&& value) { SetSuspendedState(std::move(value)); return *this;}
private:
ServiceNamespace m_serviceNamespace;
bool m_serviceNamespaceHasBeenSet;
Aws::String m_resourceId;
bool m_resourceIdHasBeenSet;
ScalableDimension m_scalableDimension;
bool m_scalableDimensionHasBeenSet;
int m_minCapacity;
bool m_minCapacityHasBeenSet;
int m_maxCapacity;
bool m_maxCapacityHasBeenSet;
Aws::String m_roleARN;
bool m_roleARNHasBeenSet;
Aws::Utils::DateTime m_creationTime;
bool m_creationTimeHasBeenSet;
SuspendedState m_suspendedState;
bool m_suspendedStateHasBeenSet;
};
} // namespace Model
} // namespace ApplicationAutoScaling
} // namespace Aws