All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.amazonaws.services.ecs.model.AutoScalingGroupProviderUpdate Maven / Gradle / Ivy

Go to download

The AWS Java SDK for the Amazon EC2 Container Service holds the client classes that are used for communicating with the Amazon EC2 Container Service

The newest version!
/*
 * Copyright 2019-2024 Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
 * the License. A copy of the License is located at
 * 
 * http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
 * CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
 * and limitations under the License.
 */
package com.amazonaws.services.ecs.model;

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

/**
 * 

* The details of the Auto Scaling group capacity provider to update. *

* * @see AWS * API Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class AutoScalingGroupProviderUpdate implements Serializable, Cloneable, StructuredPojo { /** *

* The managed scaling settings for the Auto Scaling group capacity provider. *

*/ private ManagedScaling managedScaling; /** *

* 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 doesn't work. *

*
*

* When managed termination protection is on, 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 on. For more information, see Instance Protection in the Auto Scaling User Guide. *

*

* When managed termination protection is off, your Amazon EC2 instances aren't protected from termination when the * Auto Scaling group scales in. *

*/ private String managedTerminationProtection; /** *

* The managed draining option for the Auto Scaling group capacity provider. When you enable this, Amazon ECS * manages and gracefully drains the EC2 container instances that are in the Auto Scaling group capacity provider. *

*/ private String managedDraining; /** *

* The managed scaling settings for the Auto Scaling group capacity provider. *

* * @param managedScaling * The managed scaling settings for the Auto Scaling group capacity provider. */ public void setManagedScaling(ManagedScaling managedScaling) { this.managedScaling = managedScaling; } /** *

* The managed scaling settings for the Auto Scaling group capacity provider. *

* * @return The managed scaling settings for the Auto Scaling group capacity provider. */ public ManagedScaling getManagedScaling() { return this.managedScaling; } /** *

* The managed scaling settings for the Auto Scaling group capacity provider. *

* * @param managedScaling * The managed scaling settings for the Auto Scaling group capacity provider. * @return Returns a reference to this object so that method calls can be chained together. */ public AutoScalingGroupProviderUpdate withManagedScaling(ManagedScaling managedScaling) { setManagedScaling(managedScaling); 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 doesn't work. *

*
*

* When managed termination protection is on, 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 on. For more information, see Instance Protection in the Auto Scaling User Guide. *

*

* When managed termination protection is off, your Amazon EC2 instances aren't protected from termination when the * Auto Scaling group scales in. *

* * @param 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 doesn't work. *

*
*

* When managed termination protection is on, 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 on. For more * information, see Instance Protection in the Auto Scaling User Guide. *

*

* When managed termination protection is off, your Amazon EC2 instances aren't protected from termination * when the Auto Scaling group scales in. * @see ManagedTerminationProtection */ public void setManagedTerminationProtection(String managedTerminationProtection) { this.managedTerminationProtection = 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 doesn't work. *

*
*

* When managed termination protection is on, 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 on. For more information, see Instance Protection in the Auto Scaling User Guide. *

*

* When managed termination protection is off, your Amazon EC2 instances aren't protected from termination when the * Auto Scaling group scales in. *

* * @return 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 doesn't work. *

*
*

* When managed termination protection is on, 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 on. For * more information, see Instance Protection in the Auto Scaling User Guide. *

*

* When managed termination protection is off, your Amazon EC2 instances aren't protected from termination * when the Auto Scaling group scales in. * @see ManagedTerminationProtection */ public String getManagedTerminationProtection() { return this.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 doesn't work. *

*
*

* When managed termination protection is on, 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 on. For more information, see Instance Protection in the Auto Scaling User Guide. *

*

* When managed termination protection is off, your Amazon EC2 instances aren't protected from termination when the * Auto Scaling group scales in. *

* * @param 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 doesn't work. *

*
*

* When managed termination protection is on, 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 on. For more * information, see Instance Protection in the Auto Scaling User Guide. *

*

* When managed termination protection is off, your Amazon EC2 instances aren't protected from termination * when the Auto Scaling group scales in. * @return Returns a reference to this object so that method calls can be chained together. * @see ManagedTerminationProtection */ public AutoScalingGroupProviderUpdate withManagedTerminationProtection(String managedTerminationProtection) { setManagedTerminationProtection(managedTerminationProtection); 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 doesn't work. *

*
*

* When managed termination protection is on, 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 on. For more information, see Instance Protection in the Auto Scaling User Guide. *

*

* When managed termination protection is off, your Amazon EC2 instances aren't protected from termination when the * Auto Scaling group scales in. *

* * @param 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 doesn't work. *

*
*

* When managed termination protection is on, 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 on. For more * information, see Instance Protection in the Auto Scaling User Guide. *

*

* When managed termination protection is off, your Amazon EC2 instances aren't protected from termination * when the Auto Scaling group scales in. * @return Returns a reference to this object so that method calls can be chained together. * @see ManagedTerminationProtection */ public AutoScalingGroupProviderUpdate withManagedTerminationProtection(ManagedTerminationProtection managedTerminationProtection) { this.managedTerminationProtection = managedTerminationProtection.toString(); return this; } /** *

* The managed draining option for the Auto Scaling group capacity provider. When you enable this, Amazon ECS * manages and gracefully drains the EC2 container instances that are in the Auto Scaling group capacity provider. *

* * @param managedDraining * The managed draining option for the Auto Scaling group capacity provider. When you enable this, Amazon ECS * manages and gracefully drains the EC2 container instances that are in the Auto Scaling group capacity * provider. * @see ManagedDraining */ public void setManagedDraining(String managedDraining) { this.managedDraining = managedDraining; } /** *

* The managed draining option for the Auto Scaling group capacity provider. When you enable this, Amazon ECS * manages and gracefully drains the EC2 container instances that are in the Auto Scaling group capacity provider. *

* * @return The managed draining option for the Auto Scaling group capacity provider. When you enable this, Amazon * ECS manages and gracefully drains the EC2 container instances that are in the Auto Scaling group capacity * provider. * @see ManagedDraining */ public String getManagedDraining() { return this.managedDraining; } /** *

* The managed draining option for the Auto Scaling group capacity provider. When you enable this, Amazon ECS * manages and gracefully drains the EC2 container instances that are in the Auto Scaling group capacity provider. *

* * @param managedDraining * The managed draining option for the Auto Scaling group capacity provider. When you enable this, Amazon ECS * manages and gracefully drains the EC2 container instances that are in the Auto Scaling group capacity * provider. * @return Returns a reference to this object so that method calls can be chained together. * @see ManagedDraining */ public AutoScalingGroupProviderUpdate withManagedDraining(String managedDraining) { setManagedDraining(managedDraining); return this; } /** *

* The managed draining option for the Auto Scaling group capacity provider. When you enable this, Amazon ECS * manages and gracefully drains the EC2 container instances that are in the Auto Scaling group capacity provider. *

* * @param managedDraining * The managed draining option for the Auto Scaling group capacity provider. When you enable this, Amazon ECS * manages and gracefully drains the EC2 container instances that are in the Auto Scaling group capacity * provider. * @return Returns a reference to this object so that method calls can be chained together. * @see ManagedDraining */ public AutoScalingGroupProviderUpdate withManagedDraining(ManagedDraining managedDraining) { this.managedDraining = managedDraining.toString(); return this; } /** * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be * redacted from this string using a placeholder value. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getManagedScaling() != null) sb.append("ManagedScaling: ").append(getManagedScaling()).append(","); if (getManagedTerminationProtection() != null) sb.append("ManagedTerminationProtection: ").append(getManagedTerminationProtection()).append(","); if (getManagedDraining() != null) sb.append("ManagedDraining: ").append(getManagedDraining()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof AutoScalingGroupProviderUpdate == false) return false; AutoScalingGroupProviderUpdate other = (AutoScalingGroupProviderUpdate) obj; if (other.getManagedScaling() == null ^ this.getManagedScaling() == null) return false; if (other.getManagedScaling() != null && other.getManagedScaling().equals(this.getManagedScaling()) == false) return false; if (other.getManagedTerminationProtection() == null ^ this.getManagedTerminationProtection() == null) return false; if (other.getManagedTerminationProtection() != null && other.getManagedTerminationProtection().equals(this.getManagedTerminationProtection()) == false) return false; if (other.getManagedDraining() == null ^ this.getManagedDraining() == null) return false; if (other.getManagedDraining() != null && other.getManagedDraining().equals(this.getManagedDraining()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getManagedScaling() == null) ? 0 : getManagedScaling().hashCode()); hashCode = prime * hashCode + ((getManagedTerminationProtection() == null) ? 0 : getManagedTerminationProtection().hashCode()); hashCode = prime * hashCode + ((getManagedDraining() == null) ? 0 : getManagedDraining().hashCode()); return hashCode; } @Override public AutoScalingGroupProviderUpdate clone() { try { return (AutoScalingGroupProviderUpdate) super.clone(); } catch (CloneNotSupportedException e) { throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e); } } @com.amazonaws.annotation.SdkInternalApi @Override public void marshall(ProtocolMarshaller protocolMarshaller) { com.amazonaws.services.ecs.model.transform.AutoScalingGroupProviderUpdateMarshaller.getInstance().marshall(this, protocolMarshaller); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy