/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include #include #include namespace Aws { namespace AutoScaling { namespace Model { /** */ class EnableMetricsCollectionRequest : public AutoScalingRequest { public: AWS_AUTOSCALING_API EnableMetricsCollectionRequest(); // 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 "EnableMetricsCollection"; } AWS_AUTOSCALING_API Aws::String SerializePayload() const override; protected: AWS_AUTOSCALING_API void DumpBodyToUrl(Aws::Http::URI& uri ) const override; public: /** *

The name of the Auto Scaling group.

*/ inline const Aws::String& GetAutoScalingGroupName() const{ return m_autoScalingGroupName; } /** *

The name of the Auto Scaling group.

*/ inline bool AutoScalingGroupNameHasBeenSet() const { return m_autoScalingGroupNameHasBeenSet; } /** *

The name of the Auto Scaling group.

*/ inline void SetAutoScalingGroupName(const Aws::String& value) { m_autoScalingGroupNameHasBeenSet = true; m_autoScalingGroupName = value; } /** *

The name of the Auto Scaling group.

*/ inline void SetAutoScalingGroupName(Aws::String&& value) { m_autoScalingGroupNameHasBeenSet = true; m_autoScalingGroupName = std::move(value); } /** *

The name of the Auto Scaling group.

*/ inline void SetAutoScalingGroupName(const char* value) { m_autoScalingGroupNameHasBeenSet = true; m_autoScalingGroupName.assign(value); } /** *

The name of the Auto Scaling group.

*/ inline EnableMetricsCollectionRequest& WithAutoScalingGroupName(const Aws::String& value) { SetAutoScalingGroupName(value); return *this;} /** *

The name of the Auto Scaling group.

*/ inline EnableMetricsCollectionRequest& WithAutoScalingGroupName(Aws::String&& value) { SetAutoScalingGroupName(std::move(value)); return *this;} /** *

The name of the Auto Scaling group.

*/ inline EnableMetricsCollectionRequest& WithAutoScalingGroupName(const char* value) { SetAutoScalingGroupName(value); return *this;} /** *

Identifies the metrics to enable.

You can specify one or more of the * following metrics:

  • GroupMinSize

  • *

    GroupMaxSize

  • * GroupDesiredCapacity

  • * GroupInServiceInstances

  • * GroupPendingInstances

  • * GroupStandbyInstances

  • * GroupTerminatingInstances

  • * GroupTotalInstances

  • * GroupInServiceCapacity

  • * GroupPendingCapacity

  • * GroupStandbyCapacity

  • * GroupTerminatingCapacity

  • * GroupTotalCapacity

  • * WarmPoolDesiredCapacity

  • * WarmPoolWarmedCapacity

  • * WarmPoolPendingCapacity

  • * WarmPoolTerminatingCapacity

  • * WarmPoolTotalCapacity

  • * GroupAndWarmPoolDesiredCapacity

  • * GroupAndWarmPoolTotalCapacity

If you specify * Granularity and don't specify any metrics, all metrics are * enabled.

For more information, see Auto * Scaling group metrics in the Amazon EC2 Auto Scaling User Guide.

*/ inline const Aws::Vector& GetMetrics() const{ return m_metrics; } /** *

Identifies the metrics to enable.

You can specify one or more of the * following metrics:

  • GroupMinSize

  • *

    GroupMaxSize

  • * GroupDesiredCapacity

  • * GroupInServiceInstances

  • * GroupPendingInstances

  • * GroupStandbyInstances

  • * GroupTerminatingInstances

  • * GroupTotalInstances

  • * GroupInServiceCapacity

  • * GroupPendingCapacity

  • * GroupStandbyCapacity

  • * GroupTerminatingCapacity

  • * GroupTotalCapacity

  • * WarmPoolDesiredCapacity

  • * WarmPoolWarmedCapacity

  • * WarmPoolPendingCapacity

  • * WarmPoolTerminatingCapacity

  • * WarmPoolTotalCapacity

  • * GroupAndWarmPoolDesiredCapacity

  • * GroupAndWarmPoolTotalCapacity

If you specify * Granularity and don't specify any metrics, all metrics are * enabled.

For more information, see Auto * Scaling group metrics in the Amazon EC2 Auto Scaling User Guide.

*/ inline bool MetricsHasBeenSet() const { return m_metricsHasBeenSet; } /** *

Identifies the metrics to enable.

You can specify one or more of the * following metrics:

  • GroupMinSize

  • *

    GroupMaxSize

  • * GroupDesiredCapacity

  • * GroupInServiceInstances

  • * GroupPendingInstances

  • * GroupStandbyInstances

  • * GroupTerminatingInstances

  • * GroupTotalInstances

  • * GroupInServiceCapacity

  • * GroupPendingCapacity

  • * GroupStandbyCapacity

  • * GroupTerminatingCapacity

  • * GroupTotalCapacity

  • * WarmPoolDesiredCapacity

  • * WarmPoolWarmedCapacity

  • * WarmPoolPendingCapacity

  • * WarmPoolTerminatingCapacity

  • * WarmPoolTotalCapacity

  • * GroupAndWarmPoolDesiredCapacity

  • * GroupAndWarmPoolTotalCapacity

If you specify * Granularity and don't specify any metrics, all metrics are * enabled.

For more information, see Auto * Scaling group metrics in the Amazon EC2 Auto Scaling User Guide.

*/ inline void SetMetrics(const Aws::Vector& value) { m_metricsHasBeenSet = true; m_metrics = value; } /** *

Identifies the metrics to enable.

You can specify one or more of the * following metrics:

  • GroupMinSize

  • *

    GroupMaxSize

  • * GroupDesiredCapacity

  • * GroupInServiceInstances

  • * GroupPendingInstances

  • * GroupStandbyInstances

  • * GroupTerminatingInstances

  • * GroupTotalInstances

  • * GroupInServiceCapacity

  • * GroupPendingCapacity

  • * GroupStandbyCapacity

  • * GroupTerminatingCapacity

  • * GroupTotalCapacity

  • * WarmPoolDesiredCapacity

  • * WarmPoolWarmedCapacity

  • * WarmPoolPendingCapacity

  • * WarmPoolTerminatingCapacity

  • * WarmPoolTotalCapacity

  • * GroupAndWarmPoolDesiredCapacity

  • * GroupAndWarmPoolTotalCapacity

If you specify * Granularity and don't specify any metrics, all metrics are * enabled.

For more information, see Auto * Scaling group metrics in the Amazon EC2 Auto Scaling User Guide.

*/ inline void SetMetrics(Aws::Vector&& value) { m_metricsHasBeenSet = true; m_metrics = std::move(value); } /** *

Identifies the metrics to enable.

You can specify one or more of the * following metrics:

  • GroupMinSize

  • *

    GroupMaxSize

  • * GroupDesiredCapacity

  • * GroupInServiceInstances

  • * GroupPendingInstances

  • * GroupStandbyInstances

  • * GroupTerminatingInstances

  • * GroupTotalInstances

  • * GroupInServiceCapacity

  • * GroupPendingCapacity

  • * GroupStandbyCapacity

  • * GroupTerminatingCapacity

  • * GroupTotalCapacity

  • * WarmPoolDesiredCapacity

  • * WarmPoolWarmedCapacity

  • * WarmPoolPendingCapacity

  • * WarmPoolTerminatingCapacity

  • * WarmPoolTotalCapacity

  • * GroupAndWarmPoolDesiredCapacity

  • * GroupAndWarmPoolTotalCapacity

If you specify * Granularity and don't specify any metrics, all metrics are * enabled.

For more information, see Auto * Scaling group metrics in the Amazon EC2 Auto Scaling User Guide.

*/ inline EnableMetricsCollectionRequest& WithMetrics(const Aws::Vector& value) { SetMetrics(value); return *this;} /** *

Identifies the metrics to enable.

You can specify one or more of the * following metrics:

  • GroupMinSize

  • *

    GroupMaxSize

  • * GroupDesiredCapacity

  • * GroupInServiceInstances

  • * GroupPendingInstances

  • * GroupStandbyInstances

  • * GroupTerminatingInstances

  • * GroupTotalInstances

  • * GroupInServiceCapacity

  • * GroupPendingCapacity

  • * GroupStandbyCapacity

  • * GroupTerminatingCapacity

  • * GroupTotalCapacity

  • * WarmPoolDesiredCapacity

  • * WarmPoolWarmedCapacity

  • * WarmPoolPendingCapacity

  • * WarmPoolTerminatingCapacity

  • * WarmPoolTotalCapacity

  • * GroupAndWarmPoolDesiredCapacity

  • * GroupAndWarmPoolTotalCapacity

If you specify * Granularity and don't specify any metrics, all metrics are * enabled.

For more information, see Auto * Scaling group metrics in the Amazon EC2 Auto Scaling User Guide.

*/ inline EnableMetricsCollectionRequest& WithMetrics(Aws::Vector&& value) { SetMetrics(std::move(value)); return *this;} /** *

Identifies the metrics to enable.

You can specify one or more of the * following metrics:

  • GroupMinSize

  • *

    GroupMaxSize

  • * GroupDesiredCapacity

  • * GroupInServiceInstances

  • * GroupPendingInstances

  • * GroupStandbyInstances

  • * GroupTerminatingInstances

  • * GroupTotalInstances

  • * GroupInServiceCapacity

  • * GroupPendingCapacity

  • * GroupStandbyCapacity

  • * GroupTerminatingCapacity

  • * GroupTotalCapacity

  • * WarmPoolDesiredCapacity

  • * WarmPoolWarmedCapacity

  • * WarmPoolPendingCapacity

  • * WarmPoolTerminatingCapacity

  • * WarmPoolTotalCapacity

  • * GroupAndWarmPoolDesiredCapacity

  • * GroupAndWarmPoolTotalCapacity

If you specify * Granularity and don't specify any metrics, all metrics are * enabled.

For more information, see Auto * Scaling group metrics in the Amazon EC2 Auto Scaling User Guide.

*/ inline EnableMetricsCollectionRequest& AddMetrics(const Aws::String& value) { m_metricsHasBeenSet = true; m_metrics.push_back(value); return *this; } /** *

Identifies the metrics to enable.

You can specify one or more of the * following metrics:

  • GroupMinSize

  • *

    GroupMaxSize

  • * GroupDesiredCapacity

  • * GroupInServiceInstances

  • * GroupPendingInstances

  • * GroupStandbyInstances

  • * GroupTerminatingInstances

  • * GroupTotalInstances

  • * GroupInServiceCapacity

  • * GroupPendingCapacity

  • * GroupStandbyCapacity

  • * GroupTerminatingCapacity

  • * GroupTotalCapacity

  • * WarmPoolDesiredCapacity

  • * WarmPoolWarmedCapacity

  • * WarmPoolPendingCapacity

  • * WarmPoolTerminatingCapacity

  • * WarmPoolTotalCapacity

  • * GroupAndWarmPoolDesiredCapacity

  • * GroupAndWarmPoolTotalCapacity

If you specify * Granularity and don't specify any metrics, all metrics are * enabled.

For more information, see Auto * Scaling group metrics in the Amazon EC2 Auto Scaling User Guide.

*/ inline EnableMetricsCollectionRequest& AddMetrics(Aws::String&& value) { m_metricsHasBeenSet = true; m_metrics.push_back(std::move(value)); return *this; } /** *

Identifies the metrics to enable.

You can specify one or more of the * following metrics:

  • GroupMinSize

  • *

    GroupMaxSize

  • * GroupDesiredCapacity

  • * GroupInServiceInstances

  • * GroupPendingInstances

  • * GroupStandbyInstances

  • * GroupTerminatingInstances

  • * GroupTotalInstances

  • * GroupInServiceCapacity

  • * GroupPendingCapacity

  • * GroupStandbyCapacity

  • * GroupTerminatingCapacity

  • * GroupTotalCapacity

  • * WarmPoolDesiredCapacity

  • * WarmPoolWarmedCapacity

  • * WarmPoolPendingCapacity

  • * WarmPoolTerminatingCapacity

  • * WarmPoolTotalCapacity

  • * GroupAndWarmPoolDesiredCapacity

  • * GroupAndWarmPoolTotalCapacity

If you specify * Granularity and don't specify any metrics, all metrics are * enabled.

For more information, see Auto * Scaling group metrics in the Amazon EC2 Auto Scaling User Guide.

*/ inline EnableMetricsCollectionRequest& AddMetrics(const char* value) { m_metricsHasBeenSet = true; m_metrics.push_back(value); return *this; } /** *

The frequency at which Amazon EC2 Auto Scaling sends aggregated data to * CloudWatch. The only valid value is 1Minute.

*/ inline const Aws::String& GetGranularity() const{ return m_granularity; } /** *

The frequency at which Amazon EC2 Auto Scaling sends aggregated data to * CloudWatch. The only valid value is 1Minute.

*/ inline bool GranularityHasBeenSet() const { return m_granularityHasBeenSet; } /** *

The frequency at which Amazon EC2 Auto Scaling sends aggregated data to * CloudWatch. The only valid value is 1Minute.

*/ inline void SetGranularity(const Aws::String& value) { m_granularityHasBeenSet = true; m_granularity = value; } /** *

The frequency at which Amazon EC2 Auto Scaling sends aggregated data to * CloudWatch. The only valid value is 1Minute.

*/ inline void SetGranularity(Aws::String&& value) { m_granularityHasBeenSet = true; m_granularity = std::move(value); } /** *

The frequency at which Amazon EC2 Auto Scaling sends aggregated data to * CloudWatch. The only valid value is 1Minute.

*/ inline void SetGranularity(const char* value) { m_granularityHasBeenSet = true; m_granularity.assign(value); } /** *

The frequency at which Amazon EC2 Auto Scaling sends aggregated data to * CloudWatch. The only valid value is 1Minute.

*/ inline EnableMetricsCollectionRequest& WithGranularity(const Aws::String& value) { SetGranularity(value); return *this;} /** *

The frequency at which Amazon EC2 Auto Scaling sends aggregated data to * CloudWatch. The only valid value is 1Minute.

*/ inline EnableMetricsCollectionRequest& WithGranularity(Aws::String&& value) { SetGranularity(std::move(value)); return *this;} /** *

The frequency at which Amazon EC2 Auto Scaling sends aggregated data to * CloudWatch. The only valid value is 1Minute.

*/ inline EnableMetricsCollectionRequest& WithGranularity(const char* value) { SetGranularity(value); return *this;} private: Aws::String m_autoScalingGroupName; bool m_autoScalingGroupNameHasBeenSet = false; Aws::Vector m_metrics; bool m_metricsHasBeenSet = false; Aws::String m_granularity; bool m_granularityHasBeenSet = false; }; } // namespace Model } // namespace AutoScaling } // namespace Aws