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

com.amazonaws.services.autoscaling.model.SuspendProcessesRequest Maven / Gradle / Ivy

Go to download

The Amazon Web Services SDK for Java provides Java APIs for building software on AWS' cost-effective, scalable, and reliable infrastructure products. The AWS Java SDK allows developers to code against APIs for all of Amazon's infrastructure web services (Amazon S3, Amazon EC2, Amazon SQS, Amazon Relational Database Service, Amazon AutoScaling, etc).

The newest version!
/*
 * Copyright 2010-2014 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.autoscaling.model;

import java.io.Serializable;

import com.amazonaws.AmazonWebServiceRequest;

/**
 * Container for the parameters to the {@link com.amazonaws.services.autoscaling.AmazonAutoScaling#suspendProcesses(SuspendProcessesRequest) SuspendProcesses operation}.
 * 

* Suspends Auto Scaling processes for an Auto Scaling group. To suspend * specific process types, specify them by name with the * ScalingProcesses.member.N parameter. To suspend all * process types, omit the ScalingProcesses.member.N * parameter. *

*

* IMPORTANT: Suspending either of the two primary process types, * Launch or Terminate, can prevent other process types from functioning * properly. *

*

* To resume processes that have been suspended, use ResumeProcesses For * more information on suspending and resuming Auto Scaling process, see * Suspend and Resume Auto Scaling Process * . *

* * @see com.amazonaws.services.autoscaling.AmazonAutoScaling#suspendProcesses(SuspendProcessesRequest) */ public class SuspendProcessesRequest extends AmazonWebServiceRequest implements Serializable { /** * The name or Amazon Resource Name (ARN) of the Auto Scaling group. *

* Constraints:
* Length: 1 - 1600
* Pattern: [\u0020-\uD7FF\uE000-\uFFFD\uD800\uDC00-\uDBFF\uDFFF\r\n\t]*
*/ private String autoScalingGroupName; /** * The processes that you want to suspend or resume, which can include * one or more of the following:

  • Launch
  • Terminate
  • *
  • HealthCheck
  • ReplaceUnhealthy
  • AZRebalance
  • *
  • AlarmNotification
  • ScheduledActions
  • *
  • AddToLoadBalancer

To suspend all process types, * omit this parameter. */ private com.amazonaws.internal.ListWithAutoConstructFlag scalingProcesses; /** * The name or Amazon Resource Name (ARN) of the Auto Scaling group. *

* Constraints:
* Length: 1 - 1600
* Pattern: [\u0020-\uD7FF\uE000-\uFFFD\uD800\uDC00-\uDBFF\uDFFF\r\n\t]*
* * @return The name or Amazon Resource Name (ARN) of the Auto Scaling group. */ public String getAutoScalingGroupName() { return autoScalingGroupName; } /** * The name or Amazon Resource Name (ARN) of the Auto Scaling group. *

* Constraints:
* Length: 1 - 1600
* Pattern: [\u0020-\uD7FF\uE000-\uFFFD\uD800\uDC00-\uDBFF\uDFFF\r\n\t]*
* * @param autoScalingGroupName The name or Amazon Resource Name (ARN) of the Auto Scaling group. */ public void setAutoScalingGroupName(String autoScalingGroupName) { this.autoScalingGroupName = autoScalingGroupName; } /** * The name or Amazon Resource Name (ARN) of the Auto Scaling group. *

* Returns a reference to this object so that method calls can be chained together. *

* Constraints:
* Length: 1 - 1600
* Pattern: [\u0020-\uD7FF\uE000-\uFFFD\uD800\uDC00-\uDBFF\uDFFF\r\n\t]*
* * @param autoScalingGroupName The name or Amazon Resource Name (ARN) of the Auto Scaling group. * * @return A reference to this updated object so that method calls can be chained * together. */ public SuspendProcessesRequest withAutoScalingGroupName(String autoScalingGroupName) { this.autoScalingGroupName = autoScalingGroupName; return this; } /** * The processes that you want to suspend or resume, which can include * one or more of the following:

  • Launch
  • Terminate
  • *
  • HealthCheck
  • ReplaceUnhealthy
  • AZRebalance
  • *
  • AlarmNotification
  • ScheduledActions
  • *
  • AddToLoadBalancer

To suspend all process types, * omit this parameter. * * @return The processes that you want to suspend or resume, which can include * one or more of the following:

  • Launch
  • Terminate
  • *
  • HealthCheck
  • ReplaceUnhealthy
  • AZRebalance
  • *
  • AlarmNotification
  • ScheduledActions
  • *
  • AddToLoadBalancer

To suspend all process types, * omit this parameter. */ public java.util.List getScalingProcesses() { if (scalingProcesses == null) { scalingProcesses = new com.amazonaws.internal.ListWithAutoConstructFlag(); scalingProcesses.setAutoConstruct(true); } return scalingProcesses; } /** * The processes that you want to suspend or resume, which can include * one or more of the following:

  • Launch
  • Terminate
  • *
  • HealthCheck
  • ReplaceUnhealthy
  • AZRebalance
  • *
  • AlarmNotification
  • ScheduledActions
  • *
  • AddToLoadBalancer

To suspend all process types, * omit this parameter. * * @param scalingProcesses The processes that you want to suspend or resume, which can include * one or more of the following:

  • Launch
  • Terminate
  • *
  • HealthCheck
  • ReplaceUnhealthy
  • AZRebalance
  • *
  • AlarmNotification
  • ScheduledActions
  • *
  • AddToLoadBalancer

To suspend all process types, * omit this parameter. */ public void setScalingProcesses(java.util.Collection scalingProcesses) { if (scalingProcesses == null) { this.scalingProcesses = null; return; } com.amazonaws.internal.ListWithAutoConstructFlag scalingProcessesCopy = new com.amazonaws.internal.ListWithAutoConstructFlag(scalingProcesses.size()); scalingProcessesCopy.addAll(scalingProcesses); this.scalingProcesses = scalingProcessesCopy; } /** * The processes that you want to suspend or resume, which can include * one or more of the following:

  • Launch
  • Terminate
  • *
  • HealthCheck
  • ReplaceUnhealthy
  • AZRebalance
  • *
  • AlarmNotification
  • ScheduledActions
  • *
  • AddToLoadBalancer

To suspend all process types, * omit this parameter. *

* Returns a reference to this object so that method calls can be chained together. * * @param scalingProcesses The processes that you want to suspend or resume, which can include * one or more of the following:

  • Launch
  • Terminate
  • *
  • HealthCheck
  • ReplaceUnhealthy
  • AZRebalance
  • *
  • AlarmNotification
  • ScheduledActions
  • *
  • AddToLoadBalancer

To suspend all process types, * omit this parameter. * * @return A reference to this updated object so that method calls can be chained * together. */ public SuspendProcessesRequest withScalingProcesses(String... scalingProcesses) { if (getScalingProcesses() == null) setScalingProcesses(new java.util.ArrayList(scalingProcesses.length)); for (String value : scalingProcesses) { getScalingProcesses().add(value); } return this; } /** * The processes that you want to suspend or resume, which can include * one or more of the following:

  • Launch
  • Terminate
  • *
  • HealthCheck
  • ReplaceUnhealthy
  • AZRebalance
  • *
  • AlarmNotification
  • ScheduledActions
  • *
  • AddToLoadBalancer

To suspend all process types, * omit this parameter. *

* Returns a reference to this object so that method calls can be chained together. * * @param scalingProcesses The processes that you want to suspend or resume, which can include * one or more of the following:

  • Launch
  • Terminate
  • *
  • HealthCheck
  • ReplaceUnhealthy
  • AZRebalance
  • *
  • AlarmNotification
  • ScheduledActions
  • *
  • AddToLoadBalancer

To suspend all process types, * omit this parameter. * * @return A reference to this updated object so that method calls can be chained * together. */ public SuspendProcessesRequest withScalingProcesses(java.util.Collection scalingProcesses) { if (scalingProcesses == null) { this.scalingProcesses = null; } else { com.amazonaws.internal.ListWithAutoConstructFlag scalingProcessesCopy = new com.amazonaws.internal.ListWithAutoConstructFlag(scalingProcesses.size()); scalingProcessesCopy.addAll(scalingProcesses); this.scalingProcesses = scalingProcessesCopy; } return this; } /** * Returns a string representation of this object; useful for testing and * debugging. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getAutoScalingGroupName() != null) sb.append("AutoScalingGroupName: " + getAutoScalingGroupName() + ","); if (getScalingProcesses() != null) sb.append("ScalingProcesses: " + getScalingProcesses() ); sb.append("}"); return sb.toString(); } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getAutoScalingGroupName() == null) ? 0 : getAutoScalingGroupName().hashCode()); hashCode = prime * hashCode + ((getScalingProcesses() == null) ? 0 : getScalingProcesses().hashCode()); return hashCode; } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof SuspendProcessesRequest == false) return false; SuspendProcessesRequest other = (SuspendProcessesRequest)obj; if (other.getAutoScalingGroupName() == null ^ this.getAutoScalingGroupName() == null) return false; if (other.getAutoScalingGroupName() != null && other.getAutoScalingGroupName().equals(this.getAutoScalingGroupName()) == false) return false; if (other.getScalingProcesses() == null ^ this.getScalingProcesses() == null) return false; if (other.getScalingProcesses() != null && other.getScalingProcesses().equals(this.getScalingProcesses()) == false) return false; return true; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy