/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
* SPDX-License-Identifier: Apache-2.0.
*/
#pragma once
#include The details of the Auto Scaling group for the capacity
* provider.See Also:
AWS
* API Reference
The Amazon Resource Name (ARN) that identifies the Auto Scaling group.
*/ inline const Aws::String& GetAutoScalingGroupArn() const{ return m_autoScalingGroupArn; } /** *The Amazon Resource Name (ARN) that identifies the Auto Scaling group.
*/ inline bool AutoScalingGroupArnHasBeenSet() const { return m_autoScalingGroupArnHasBeenSet; } /** *The Amazon Resource Name (ARN) that identifies the Auto Scaling group.
*/ inline void SetAutoScalingGroupArn(const Aws::String& value) { m_autoScalingGroupArnHasBeenSet = true; m_autoScalingGroupArn = value; } /** *The Amazon Resource Name (ARN) that identifies the Auto Scaling group.
*/ inline void SetAutoScalingGroupArn(Aws::String&& value) { m_autoScalingGroupArnHasBeenSet = true; m_autoScalingGroupArn = std::move(value); } /** *The Amazon Resource Name (ARN) that identifies the Auto Scaling group.
*/ inline void SetAutoScalingGroupArn(const char* value) { m_autoScalingGroupArnHasBeenSet = true; m_autoScalingGroupArn.assign(value); } /** *The Amazon Resource Name (ARN) that identifies the Auto Scaling group.
*/ inline AutoScalingGroupProvider& WithAutoScalingGroupArn(const Aws::String& value) { SetAutoScalingGroupArn(value); return *this;} /** *The Amazon Resource Name (ARN) that identifies the Auto Scaling group.
*/ inline AutoScalingGroupProvider& WithAutoScalingGroupArn(Aws::String&& value) { SetAutoScalingGroupArn(std::move(value)); return *this;} /** *The Amazon Resource Name (ARN) that identifies the Auto Scaling group.
*/ inline AutoScalingGroupProvider& WithAutoScalingGroupArn(const char* value) { SetAutoScalingGroupArn(value); return *this;} /** *The managed scaling settings for the Auto Scaling group capacity * provider.
*/ inline const ManagedScaling& GetManagedScaling() const{ return m_managedScaling; } /** *The managed scaling settings for the Auto Scaling group capacity * provider.
*/ inline bool ManagedScalingHasBeenSet() const { return m_managedScalingHasBeenSet; } /** *The managed scaling settings for the Auto Scaling group capacity * provider.
*/ inline void SetManagedScaling(const ManagedScaling& value) { m_managedScalingHasBeenSet = true; m_managedScaling = value; } /** *The managed scaling settings for the Auto Scaling group capacity * provider.
*/ inline void SetManagedScaling(ManagedScaling&& value) { m_managedScalingHasBeenSet = true; m_managedScaling = std::move(value); } /** *The managed scaling settings for the Auto Scaling group capacity * provider.
*/ inline AutoScalingGroupProvider& WithManagedScaling(const ManagedScaling& value) { SetManagedScaling(value); return *this;} /** *The managed scaling settings for the Auto Scaling group capacity * provider.
*/ inline AutoScalingGroupProvider& WithManagedScaling(ManagedScaling&& value) { SetManagedScaling(std::move(value)); return *this;} /** *The managed termination protection setting to use for the Auto Scaling group * capacity provider. This determines whether the Auto Scaling group has managed * termination protection.
When using managed termination * protection, managed scaling must also be used otherwise managed termination * protection will not work.
When managed termination * protection is enabled, Amazon ECS prevents the Amazon EC2 instances in an Auto * Scaling group that contain tasks from being terminated during a scale-in action. * The Auto Scaling group and each instance in the Auto Scaling group must have * instance protection from scale-in actions enabled as well. For more information, * see Instance * Protection in the AWS Auto Scaling User Guide.
When managed * termination protection is disabled, your Amazon EC2 instances are not protected * from termination when the Auto Scaling group scales in.
*/ inline const ManagedTerminationProtection& GetManagedTerminationProtection() const{ return m_managedTerminationProtection; } /** *The managed termination protection setting to use for the Auto Scaling group * capacity provider. This determines whether the Auto Scaling group has managed * termination protection.
When using managed termination * protection, managed scaling must also be used otherwise managed termination * protection will not work.
When managed termination * protection is enabled, Amazon ECS prevents the Amazon EC2 instances in an Auto * Scaling group that contain tasks from being terminated during a scale-in action. * The Auto Scaling group and each instance in the Auto Scaling group must have * instance protection from scale-in actions enabled as well. For more information, * see Instance * Protection in the AWS Auto Scaling User Guide.
When managed * termination protection is disabled, your Amazon EC2 instances are not protected * from termination when the Auto Scaling group scales in.
*/ inline bool ManagedTerminationProtectionHasBeenSet() const { return m_managedTerminationProtectionHasBeenSet; } /** *The managed termination protection setting to use for the Auto Scaling group * capacity provider. This determines whether the Auto Scaling group has managed * termination protection.
When using managed termination * protection, managed scaling must also be used otherwise managed termination * protection will not work.
When managed termination * protection is enabled, Amazon ECS prevents the Amazon EC2 instances in an Auto * Scaling group that contain tasks from being terminated during a scale-in action. * The Auto Scaling group and each instance in the Auto Scaling group must have * instance protection from scale-in actions enabled as well. For more information, * see Instance * Protection in the AWS Auto Scaling User Guide.
When managed * termination protection is disabled, your Amazon EC2 instances are not protected * from termination when the Auto Scaling group scales in.
*/ inline void SetManagedTerminationProtection(const ManagedTerminationProtection& value) { m_managedTerminationProtectionHasBeenSet = true; m_managedTerminationProtection = value; } /** *The managed termination protection setting to use for the Auto Scaling group * capacity provider. This determines whether the Auto Scaling group has managed * termination protection.
When using managed termination * protection, managed scaling must also be used otherwise managed termination * protection will not work.
When managed termination * protection is enabled, Amazon ECS prevents the Amazon EC2 instances in an Auto * Scaling group that contain tasks from being terminated during a scale-in action. * The Auto Scaling group and each instance in the Auto Scaling group must have * instance protection from scale-in actions enabled as well. For more information, * see Instance * Protection in the AWS Auto Scaling User Guide.
When managed * termination protection is disabled, your Amazon EC2 instances are not protected * from termination when the Auto Scaling group scales in.
*/ inline void SetManagedTerminationProtection(ManagedTerminationProtection&& value) { m_managedTerminationProtectionHasBeenSet = true; m_managedTerminationProtection = std::move(value); } /** *The managed termination protection setting to use for the Auto Scaling group * capacity provider. This determines whether the Auto Scaling group has managed * termination protection.
When using managed termination * protection, managed scaling must also be used otherwise managed termination * protection will not work.
When managed termination * protection is enabled, Amazon ECS prevents the Amazon EC2 instances in an Auto * Scaling group that contain tasks from being terminated during a scale-in action. * The Auto Scaling group and each instance in the Auto Scaling group must have * instance protection from scale-in actions enabled as well. For more information, * see Instance * Protection in the AWS Auto Scaling User Guide.
When managed * termination protection is disabled, your Amazon EC2 instances are not protected * from termination when the Auto Scaling group scales in.
*/ inline AutoScalingGroupProvider& WithManagedTerminationProtection(const ManagedTerminationProtection& value) { SetManagedTerminationProtection(value); return *this;} /** *The managed termination protection setting to use for the Auto Scaling group * capacity provider. This determines whether the Auto Scaling group has managed * termination protection.
When using managed termination * protection, managed scaling must also be used otherwise managed termination * protection will not work.
When managed termination * protection is enabled, Amazon ECS prevents the Amazon EC2 instances in an Auto * Scaling group that contain tasks from being terminated during a scale-in action. * The Auto Scaling group and each instance in the Auto Scaling group must have * instance protection from scale-in actions enabled as well. For more information, * see Instance * Protection in the AWS Auto Scaling User Guide.
When managed * termination protection is disabled, your Amazon EC2 instances are not protected * from termination when the Auto Scaling group scales in.
*/ inline AutoScalingGroupProvider& WithManagedTerminationProtection(ManagedTerminationProtection&& value) { SetManagedTerminationProtection(std::move(value)); return *this;} private: Aws::String m_autoScalingGroupArn; bool m_autoScalingGroupArnHasBeenSet; ManagedScaling m_managedScaling; bool m_managedScalingHasBeenSet; ManagedTerminationProtection m_managedTerminationProtection; bool m_managedTerminationProtectionHasBeenSet; }; } // namespace Model } // namespace ECS } // namespace Aws