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

com.amazonaws.services.codedeploy.model.CreateDeploymentGroupRequest Maven / Gradle / Ivy

Go to download

The AWS Java SDK for AWS CodeDeploy module holds the client classes that are used for communicating with AWS CodeDeploy 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.codedeploy.model;

import java.io.Serializable;
import javax.annotation.Generated;

import com.amazonaws.AmazonWebServiceRequest;

/**
 * 

* Represents the input of a CreateDeploymentGroup operation. *

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

* The name of an CodeDeploy application associated with the user or Amazon Web Services account. *

*/ private String applicationName; /** *

* The name of a new deployment group for the specified application. *

*/ private String deploymentGroupName; /** *

* If specified, the deployment configuration name can be either one of the predefined configurations provided with * CodeDeploy or a custom deployment configuration that you create by calling the create deployment configuration * operation. *

*

* CodeDeployDefault.OneAtATime is the default deployment configuration. It is used if a configuration * isn't specified for the deployment or deployment group. *

*

* For more information about the predefined deployment configurations in CodeDeploy, see Working with * Deployment Configurations in CodeDeploy in the CodeDeploy User Guide. *

*/ private String deploymentConfigName; /** *

* The Amazon EC2 tags on which to filter. The deployment group includes Amazon EC2 instances with any of the * specified tags. Cannot be used in the same call as ec2TagSet. *

*/ private com.amazonaws.internal.SdkInternalList ec2TagFilters; /** *

* The on-premises instance tags on which to filter. The deployment group includes on-premises instances with any of * the specified tags. Cannot be used in the same call as OnPremisesTagSet. *

*/ private com.amazonaws.internal.SdkInternalList onPremisesInstanceTagFilters; /** *

* A list of associated Amazon EC2 Auto Scaling groups. *

*/ private com.amazonaws.internal.SdkInternalList autoScalingGroups; /** *

* A service role Amazon Resource Name (ARN) that allows CodeDeploy to act on the user's behalf when interacting * with Amazon Web Services services. *

*/ private String serviceRoleArn; /** *

* Information about triggers to create when the deployment group is created. For examples, see Create a Trigger for an * CodeDeploy Event in the CodeDeploy User Guide. *

*/ private com.amazonaws.internal.SdkInternalList triggerConfigurations; /** *

* Information to add about Amazon CloudWatch alarms when the deployment group is created. *

*/ private AlarmConfiguration alarmConfiguration; /** *

* Configuration information for an automatic rollback that is added when a deployment group is created. *

*/ private AutoRollbackConfiguration autoRollbackConfiguration; /** *

* Indicates what happens when new Amazon EC2 instances are launched mid-deployment and do not receive the deployed * application revision. *

*

* If this option is set to UPDATE or is unspecified, CodeDeploy initiates one or more 'auto-update * outdated instances' deployments to apply the deployed application revision to the new Amazon EC2 instances. *

*

* If this option is set to IGNORE, CodeDeploy does not initiate a deployment to update the new Amazon * EC2 instances. This may result in instances having different revisions. *

*/ private String outdatedInstancesStrategy; /** *

* Information about the type of deployment, in-place or blue/green, that you want to run and whether to route * deployment traffic behind a load balancer. *

*/ private DeploymentStyle deploymentStyle; /** *

* Information about blue/green deployment options for a deployment group. *

*/ private BlueGreenDeploymentConfiguration blueGreenDeploymentConfiguration; /** *

* Information about the load balancer used in a deployment. *

*/ private LoadBalancerInfo loadBalancerInfo; /** *

* Information about groups of tags applied to Amazon EC2 instances. The deployment group includes only Amazon EC2 * instances identified by all the tag groups. Cannot be used in the same call as ec2TagFilters. *

*/ private EC2TagSet ec2TagSet; /** *

* The target Amazon ECS services in the deployment group. This applies only to deployment groups that use the * Amazon ECS compute platform. A target Amazon ECS service is specified as an Amazon ECS cluster and service name * pair using the format <clustername>:<servicename>. *

*/ private com.amazonaws.internal.SdkInternalList ecsServices; /** *

* Information about groups of tags applied to on-premises instances. The deployment group includes only on-premises * instances identified by all of the tag groups. Cannot be used in the same call as * onPremisesInstanceTagFilters. *

*/ private OnPremisesTagSet onPremisesTagSet; /** *

* The metadata that you apply to CodeDeploy deployment groups to help you organize and categorize them. Each tag * consists of a key and an optional value, both of which you define. *

*/ private com.amazonaws.internal.SdkInternalList tags; /** *

* This parameter only applies if you are using CodeDeploy with Amazon EC2 Auto Scaling. For more information, see * Integrating * CodeDeploy with Amazon EC2 Auto Scaling in the CodeDeploy User Guide. *

*

* Set terminationHookEnabled to true to have CodeDeploy install a termination hook into * your Auto Scaling group when you create a deployment group. When this hook is installed, CodeDeploy will perform * termination deployments. *

*

* For information about termination deployments, see Enabling termination deployments during Auto Scaling scale-in events in the CodeDeploy User Guide. *

*

* For more information about Auto Scaling scale-in events, see the Scale in topic in the Amazon EC2 Auto Scaling User Guide. *

*/ private Boolean terminationHookEnabled; /** *

* The name of an CodeDeploy application associated with the user or Amazon Web Services account. *

* * @param applicationName * The name of an CodeDeploy application associated with the user or Amazon Web Services account. */ public void setApplicationName(String applicationName) { this.applicationName = applicationName; } /** *

* The name of an CodeDeploy application associated with the user or Amazon Web Services account. *

* * @return The name of an CodeDeploy application associated with the user or Amazon Web Services account. */ public String getApplicationName() { return this.applicationName; } /** *

* The name of an CodeDeploy application associated with the user or Amazon Web Services account. *

* * @param applicationName * The name of an CodeDeploy application associated with the user or Amazon Web Services account. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withApplicationName(String applicationName) { setApplicationName(applicationName); return this; } /** *

* The name of a new deployment group for the specified application. *

* * @param deploymentGroupName * The name of a new deployment group for the specified application. */ public void setDeploymentGroupName(String deploymentGroupName) { this.deploymentGroupName = deploymentGroupName; } /** *

* The name of a new deployment group for the specified application. *

* * @return The name of a new deployment group for the specified application. */ public String getDeploymentGroupName() { return this.deploymentGroupName; } /** *

* The name of a new deployment group for the specified application. *

* * @param deploymentGroupName * The name of a new deployment group for the specified application. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withDeploymentGroupName(String deploymentGroupName) { setDeploymentGroupName(deploymentGroupName); return this; } /** *

* If specified, the deployment configuration name can be either one of the predefined configurations provided with * CodeDeploy or a custom deployment configuration that you create by calling the create deployment configuration * operation. *

*

* CodeDeployDefault.OneAtATime is the default deployment configuration. It is used if a configuration * isn't specified for the deployment or deployment group. *

*

* For more information about the predefined deployment configurations in CodeDeploy, see Working with * Deployment Configurations in CodeDeploy in the CodeDeploy User Guide. *

* * @param deploymentConfigName * If specified, the deployment configuration name can be either one of the predefined configurations * provided with CodeDeploy or a custom deployment configuration that you create by calling the create * deployment configuration operation.

*

* CodeDeployDefault.OneAtATime is the default deployment configuration. It is used if a * configuration isn't specified for the deployment or deployment group. *

*

* For more information about the predefined deployment configurations in CodeDeploy, see Working with * Deployment Configurations in CodeDeploy in the CodeDeploy User Guide. */ public void setDeploymentConfigName(String deploymentConfigName) { this.deploymentConfigName = deploymentConfigName; } /** *

* If specified, the deployment configuration name can be either one of the predefined configurations provided with * CodeDeploy or a custom deployment configuration that you create by calling the create deployment configuration * operation. *

*

* CodeDeployDefault.OneAtATime is the default deployment configuration. It is used if a configuration * isn't specified for the deployment or deployment group. *

*

* For more information about the predefined deployment configurations in CodeDeploy, see Working with * Deployment Configurations in CodeDeploy in the CodeDeploy User Guide. *

* * @return If specified, the deployment configuration name can be either one of the predefined configurations * provided with CodeDeploy or a custom deployment configuration that you create by calling the create * deployment configuration operation.

*

* CodeDeployDefault.OneAtATime is the default deployment configuration. It is used if a * configuration isn't specified for the deployment or deployment group. *

*

* For more information about the predefined deployment configurations in CodeDeploy, see Working * with Deployment Configurations in CodeDeploy in the CodeDeploy User Guide. */ public String getDeploymentConfigName() { return this.deploymentConfigName; } /** *

* If specified, the deployment configuration name can be either one of the predefined configurations provided with * CodeDeploy or a custom deployment configuration that you create by calling the create deployment configuration * operation. *

*

* CodeDeployDefault.OneAtATime is the default deployment configuration. It is used if a configuration * isn't specified for the deployment or deployment group. *

*

* For more information about the predefined deployment configurations in CodeDeploy, see Working with * Deployment Configurations in CodeDeploy in the CodeDeploy User Guide. *

* * @param deploymentConfigName * If specified, the deployment configuration name can be either one of the predefined configurations * provided with CodeDeploy or a custom deployment configuration that you create by calling the create * deployment configuration operation.

*

* CodeDeployDefault.OneAtATime is the default deployment configuration. It is used if a * configuration isn't specified for the deployment or deployment group. *

*

* For more information about the predefined deployment configurations in CodeDeploy, see Working with * Deployment Configurations in CodeDeploy in the CodeDeploy User Guide. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withDeploymentConfigName(String deploymentConfigName) { setDeploymentConfigName(deploymentConfigName); return this; } /** *

* The Amazon EC2 tags on which to filter. The deployment group includes Amazon EC2 instances with any of the * specified tags. Cannot be used in the same call as ec2TagSet. *

* * @return The Amazon EC2 tags on which to filter. The deployment group includes Amazon EC2 instances with any of * the specified tags. Cannot be used in the same call as ec2TagSet. */ public java.util.List getEc2TagFilters() { if (ec2TagFilters == null) { ec2TagFilters = new com.amazonaws.internal.SdkInternalList(); } return ec2TagFilters; } /** *

* The Amazon EC2 tags on which to filter. The deployment group includes Amazon EC2 instances with any of the * specified tags. Cannot be used in the same call as ec2TagSet. *

* * @param ec2TagFilters * The Amazon EC2 tags on which to filter. The deployment group includes Amazon EC2 instances with any of the * specified tags. Cannot be used in the same call as ec2TagSet. */ public void setEc2TagFilters(java.util.Collection ec2TagFilters) { if (ec2TagFilters == null) { this.ec2TagFilters = null; return; } this.ec2TagFilters = new com.amazonaws.internal.SdkInternalList(ec2TagFilters); } /** *

* The Amazon EC2 tags on which to filter. The deployment group includes Amazon EC2 instances with any of the * specified tags. Cannot be used in the same call as ec2TagSet. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setEc2TagFilters(java.util.Collection)} or {@link #withEc2TagFilters(java.util.Collection)} if you want * to override the existing values. *

* * @param ec2TagFilters * The Amazon EC2 tags on which to filter. The deployment group includes Amazon EC2 instances with any of the * specified tags. Cannot be used in the same call as ec2TagSet. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withEc2TagFilters(EC2TagFilter... ec2TagFilters) { if (this.ec2TagFilters == null) { setEc2TagFilters(new com.amazonaws.internal.SdkInternalList(ec2TagFilters.length)); } for (EC2TagFilter ele : ec2TagFilters) { this.ec2TagFilters.add(ele); } return this; } /** *

* The Amazon EC2 tags on which to filter. The deployment group includes Amazon EC2 instances with any of the * specified tags. Cannot be used in the same call as ec2TagSet. *

* * @param ec2TagFilters * The Amazon EC2 tags on which to filter. The deployment group includes Amazon EC2 instances with any of the * specified tags. Cannot be used in the same call as ec2TagSet. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withEc2TagFilters(java.util.Collection ec2TagFilters) { setEc2TagFilters(ec2TagFilters); return this; } /** *

* The on-premises instance tags on which to filter. The deployment group includes on-premises instances with any of * the specified tags. Cannot be used in the same call as OnPremisesTagSet. *

* * @return The on-premises instance tags on which to filter. The deployment group includes on-premises instances * with any of the specified tags. Cannot be used in the same call as OnPremisesTagSet. */ public java.util.List getOnPremisesInstanceTagFilters() { if (onPremisesInstanceTagFilters == null) { onPremisesInstanceTagFilters = new com.amazonaws.internal.SdkInternalList(); } return onPremisesInstanceTagFilters; } /** *

* The on-premises instance tags on which to filter. The deployment group includes on-premises instances with any of * the specified tags. Cannot be used in the same call as OnPremisesTagSet. *

* * @param onPremisesInstanceTagFilters * The on-premises instance tags on which to filter. The deployment group includes on-premises instances with * any of the specified tags. Cannot be used in the same call as OnPremisesTagSet. */ public void setOnPremisesInstanceTagFilters(java.util.Collection onPremisesInstanceTagFilters) { if (onPremisesInstanceTagFilters == null) { this.onPremisesInstanceTagFilters = null; return; } this.onPremisesInstanceTagFilters = new com.amazonaws.internal.SdkInternalList(onPremisesInstanceTagFilters); } /** *

* The on-premises instance tags on which to filter. The deployment group includes on-premises instances with any of * the specified tags. Cannot be used in the same call as OnPremisesTagSet. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setOnPremisesInstanceTagFilters(java.util.Collection)} or * {@link #withOnPremisesInstanceTagFilters(java.util.Collection)} if you want to override the existing values. *

* * @param onPremisesInstanceTagFilters * The on-premises instance tags on which to filter. The deployment group includes on-premises instances with * any of the specified tags. Cannot be used in the same call as OnPremisesTagSet. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withOnPremisesInstanceTagFilters(TagFilter... onPremisesInstanceTagFilters) { if (this.onPremisesInstanceTagFilters == null) { setOnPremisesInstanceTagFilters(new com.amazonaws.internal.SdkInternalList(onPremisesInstanceTagFilters.length)); } for (TagFilter ele : onPremisesInstanceTagFilters) { this.onPremisesInstanceTagFilters.add(ele); } return this; } /** *

* The on-premises instance tags on which to filter. The deployment group includes on-premises instances with any of * the specified tags. Cannot be used in the same call as OnPremisesTagSet. *

* * @param onPremisesInstanceTagFilters * The on-premises instance tags on which to filter. The deployment group includes on-premises instances with * any of the specified tags. Cannot be used in the same call as OnPremisesTagSet. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withOnPremisesInstanceTagFilters(java.util.Collection onPremisesInstanceTagFilters) { setOnPremisesInstanceTagFilters(onPremisesInstanceTagFilters); return this; } /** *

* A list of associated Amazon EC2 Auto Scaling groups. *

* * @return A list of associated Amazon EC2 Auto Scaling groups. */ public java.util.List getAutoScalingGroups() { if (autoScalingGroups == null) { autoScalingGroups = new com.amazonaws.internal.SdkInternalList(); } return autoScalingGroups; } /** *

* A list of associated Amazon EC2 Auto Scaling groups. *

* * @param autoScalingGroups * A list of associated Amazon EC2 Auto Scaling groups. */ public void setAutoScalingGroups(java.util.Collection autoScalingGroups) { if (autoScalingGroups == null) { this.autoScalingGroups = null; return; } this.autoScalingGroups = new com.amazonaws.internal.SdkInternalList(autoScalingGroups); } /** *

* A list of associated Amazon EC2 Auto Scaling groups. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setAutoScalingGroups(java.util.Collection)} or {@link #withAutoScalingGroups(java.util.Collection)} if * you want to override the existing values. *

* * @param autoScalingGroups * A list of associated Amazon EC2 Auto Scaling groups. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withAutoScalingGroups(String... autoScalingGroups) { if (this.autoScalingGroups == null) { setAutoScalingGroups(new com.amazonaws.internal.SdkInternalList(autoScalingGroups.length)); } for (String ele : autoScalingGroups) { this.autoScalingGroups.add(ele); } return this; } /** *

* A list of associated Amazon EC2 Auto Scaling groups. *

* * @param autoScalingGroups * A list of associated Amazon EC2 Auto Scaling groups. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withAutoScalingGroups(java.util.Collection autoScalingGroups) { setAutoScalingGroups(autoScalingGroups); return this; } /** *

* A service role Amazon Resource Name (ARN) that allows CodeDeploy to act on the user's behalf when interacting * with Amazon Web Services services. *

* * @param serviceRoleArn * A service role Amazon Resource Name (ARN) that allows CodeDeploy to act on the user's behalf when * interacting with Amazon Web Services services. */ public void setServiceRoleArn(String serviceRoleArn) { this.serviceRoleArn = serviceRoleArn; } /** *

* A service role Amazon Resource Name (ARN) that allows CodeDeploy to act on the user's behalf when interacting * with Amazon Web Services services. *

* * @return A service role Amazon Resource Name (ARN) that allows CodeDeploy to act on the user's behalf when * interacting with Amazon Web Services services. */ public String getServiceRoleArn() { return this.serviceRoleArn; } /** *

* A service role Amazon Resource Name (ARN) that allows CodeDeploy to act on the user's behalf when interacting * with Amazon Web Services services. *

* * @param serviceRoleArn * A service role Amazon Resource Name (ARN) that allows CodeDeploy to act on the user's behalf when * interacting with Amazon Web Services services. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withServiceRoleArn(String serviceRoleArn) { setServiceRoleArn(serviceRoleArn); return this; } /** *

* Information about triggers to create when the deployment group is created. For examples, see Create a Trigger for an * CodeDeploy Event in the CodeDeploy User Guide. *

* * @return Information about triggers to create when the deployment group is created. For examples, see Create a Trigger * for an CodeDeploy Event in the CodeDeploy User Guide. */ public java.util.List getTriggerConfigurations() { if (triggerConfigurations == null) { triggerConfigurations = new com.amazonaws.internal.SdkInternalList(); } return triggerConfigurations; } /** *

* Information about triggers to create when the deployment group is created. For examples, see Create a Trigger for an * CodeDeploy Event in the CodeDeploy User Guide. *

* * @param triggerConfigurations * Information about triggers to create when the deployment group is created. For examples, see Create a Trigger for * an CodeDeploy Event in the CodeDeploy User Guide. */ public void setTriggerConfigurations(java.util.Collection triggerConfigurations) { if (triggerConfigurations == null) { this.triggerConfigurations = null; return; } this.triggerConfigurations = new com.amazonaws.internal.SdkInternalList(triggerConfigurations); } /** *

* Information about triggers to create when the deployment group is created. For examples, see Create a Trigger for an * CodeDeploy Event in the CodeDeploy User Guide. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setTriggerConfigurations(java.util.Collection)} or * {@link #withTriggerConfigurations(java.util.Collection)} if you want to override the existing values. *

* * @param triggerConfigurations * Information about triggers to create when the deployment group is created. For examples, see Create a Trigger for * an CodeDeploy Event in the CodeDeploy User Guide. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withTriggerConfigurations(TriggerConfig... triggerConfigurations) { if (this.triggerConfigurations == null) { setTriggerConfigurations(new com.amazonaws.internal.SdkInternalList(triggerConfigurations.length)); } for (TriggerConfig ele : triggerConfigurations) { this.triggerConfigurations.add(ele); } return this; } /** *

* Information about triggers to create when the deployment group is created. For examples, see Create a Trigger for an * CodeDeploy Event in the CodeDeploy User Guide. *

* * @param triggerConfigurations * Information about triggers to create when the deployment group is created. For examples, see Create a Trigger for * an CodeDeploy Event in the CodeDeploy User Guide. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withTriggerConfigurations(java.util.Collection triggerConfigurations) { setTriggerConfigurations(triggerConfigurations); return this; } /** *

* Information to add about Amazon CloudWatch alarms when the deployment group is created. *

* * @param alarmConfiguration * Information to add about Amazon CloudWatch alarms when the deployment group is created. */ public void setAlarmConfiguration(AlarmConfiguration alarmConfiguration) { this.alarmConfiguration = alarmConfiguration; } /** *

* Information to add about Amazon CloudWatch alarms when the deployment group is created. *

* * @return Information to add about Amazon CloudWatch alarms when the deployment group is created. */ public AlarmConfiguration getAlarmConfiguration() { return this.alarmConfiguration; } /** *

* Information to add about Amazon CloudWatch alarms when the deployment group is created. *

* * @param alarmConfiguration * Information to add about Amazon CloudWatch alarms when the deployment group is created. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withAlarmConfiguration(AlarmConfiguration alarmConfiguration) { setAlarmConfiguration(alarmConfiguration); return this; } /** *

* Configuration information for an automatic rollback that is added when a deployment group is created. *

* * @param autoRollbackConfiguration * Configuration information for an automatic rollback that is added when a deployment group is created. */ public void setAutoRollbackConfiguration(AutoRollbackConfiguration autoRollbackConfiguration) { this.autoRollbackConfiguration = autoRollbackConfiguration; } /** *

* Configuration information for an automatic rollback that is added when a deployment group is created. *

* * @return Configuration information for an automatic rollback that is added when a deployment group is created. */ public AutoRollbackConfiguration getAutoRollbackConfiguration() { return this.autoRollbackConfiguration; } /** *

* Configuration information for an automatic rollback that is added when a deployment group is created. *

* * @param autoRollbackConfiguration * Configuration information for an automatic rollback that is added when a deployment group is created. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withAutoRollbackConfiguration(AutoRollbackConfiguration autoRollbackConfiguration) { setAutoRollbackConfiguration(autoRollbackConfiguration); return this; } /** *

* Indicates what happens when new Amazon EC2 instances are launched mid-deployment and do not receive the deployed * application revision. *

*

* If this option is set to UPDATE or is unspecified, CodeDeploy initiates one or more 'auto-update * outdated instances' deployments to apply the deployed application revision to the new Amazon EC2 instances. *

*

* If this option is set to IGNORE, CodeDeploy does not initiate a deployment to update the new Amazon * EC2 instances. This may result in instances having different revisions. *

* * @param outdatedInstancesStrategy * Indicates what happens when new Amazon EC2 instances are launched mid-deployment and do not receive the * deployed application revision.

*

* If this option is set to UPDATE or is unspecified, CodeDeploy initiates one or more * 'auto-update outdated instances' deployments to apply the deployed application revision to the new Amazon * EC2 instances. *

*

* If this option is set to IGNORE, CodeDeploy does not initiate a deployment to update the new * Amazon EC2 instances. This may result in instances having different revisions. * @see OutdatedInstancesStrategy */ public void setOutdatedInstancesStrategy(String outdatedInstancesStrategy) { this.outdatedInstancesStrategy = outdatedInstancesStrategy; } /** *

* Indicates what happens when new Amazon EC2 instances are launched mid-deployment and do not receive the deployed * application revision. *

*

* If this option is set to UPDATE or is unspecified, CodeDeploy initiates one or more 'auto-update * outdated instances' deployments to apply the deployed application revision to the new Amazon EC2 instances. *

*

* If this option is set to IGNORE, CodeDeploy does not initiate a deployment to update the new Amazon * EC2 instances. This may result in instances having different revisions. *

* * @return Indicates what happens when new Amazon EC2 instances are launched mid-deployment and do not receive the * deployed application revision.

*

* If this option is set to UPDATE or is unspecified, CodeDeploy initiates one or more * 'auto-update outdated instances' deployments to apply the deployed application revision to the new Amazon * EC2 instances. *

*

* If this option is set to IGNORE, CodeDeploy does not initiate a deployment to update the new * Amazon EC2 instances. This may result in instances having different revisions. * @see OutdatedInstancesStrategy */ public String getOutdatedInstancesStrategy() { return this.outdatedInstancesStrategy; } /** *

* Indicates what happens when new Amazon EC2 instances are launched mid-deployment and do not receive the deployed * application revision. *

*

* If this option is set to UPDATE or is unspecified, CodeDeploy initiates one or more 'auto-update * outdated instances' deployments to apply the deployed application revision to the new Amazon EC2 instances. *

*

* If this option is set to IGNORE, CodeDeploy does not initiate a deployment to update the new Amazon * EC2 instances. This may result in instances having different revisions. *

* * @param outdatedInstancesStrategy * Indicates what happens when new Amazon EC2 instances are launched mid-deployment and do not receive the * deployed application revision.

*

* If this option is set to UPDATE or is unspecified, CodeDeploy initiates one or more * 'auto-update outdated instances' deployments to apply the deployed application revision to the new Amazon * EC2 instances. *

*

* If this option is set to IGNORE, CodeDeploy does not initiate a deployment to update the new * Amazon EC2 instances. This may result in instances having different revisions. * @return Returns a reference to this object so that method calls can be chained together. * @see OutdatedInstancesStrategy */ public CreateDeploymentGroupRequest withOutdatedInstancesStrategy(String outdatedInstancesStrategy) { setOutdatedInstancesStrategy(outdatedInstancesStrategy); return this; } /** *

* Indicates what happens when new Amazon EC2 instances are launched mid-deployment and do not receive the deployed * application revision. *

*

* If this option is set to UPDATE or is unspecified, CodeDeploy initiates one or more 'auto-update * outdated instances' deployments to apply the deployed application revision to the new Amazon EC2 instances. *

*

* If this option is set to IGNORE, CodeDeploy does not initiate a deployment to update the new Amazon * EC2 instances. This may result in instances having different revisions. *

* * @param outdatedInstancesStrategy * Indicates what happens when new Amazon EC2 instances are launched mid-deployment and do not receive the * deployed application revision.

*

* If this option is set to UPDATE or is unspecified, CodeDeploy initiates one or more * 'auto-update outdated instances' deployments to apply the deployed application revision to the new Amazon * EC2 instances. *

*

* If this option is set to IGNORE, CodeDeploy does not initiate a deployment to update the new * Amazon EC2 instances. This may result in instances having different revisions. * @return Returns a reference to this object so that method calls can be chained together. * @see OutdatedInstancesStrategy */ public CreateDeploymentGroupRequest withOutdatedInstancesStrategy(OutdatedInstancesStrategy outdatedInstancesStrategy) { this.outdatedInstancesStrategy = outdatedInstancesStrategy.toString(); return this; } /** *

* Information about the type of deployment, in-place or blue/green, that you want to run and whether to route * deployment traffic behind a load balancer. *

* * @param deploymentStyle * Information about the type of deployment, in-place or blue/green, that you want to run and whether to * route deployment traffic behind a load balancer. */ public void setDeploymentStyle(DeploymentStyle deploymentStyle) { this.deploymentStyle = deploymentStyle; } /** *

* Information about the type of deployment, in-place or blue/green, that you want to run and whether to route * deployment traffic behind a load balancer. *

* * @return Information about the type of deployment, in-place or blue/green, that you want to run and whether to * route deployment traffic behind a load balancer. */ public DeploymentStyle getDeploymentStyle() { return this.deploymentStyle; } /** *

* Information about the type of deployment, in-place or blue/green, that you want to run and whether to route * deployment traffic behind a load balancer. *

* * @param deploymentStyle * Information about the type of deployment, in-place or blue/green, that you want to run and whether to * route deployment traffic behind a load balancer. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withDeploymentStyle(DeploymentStyle deploymentStyle) { setDeploymentStyle(deploymentStyle); return this; } /** *

* Information about blue/green deployment options for a deployment group. *

* * @param blueGreenDeploymentConfiguration * Information about blue/green deployment options for a deployment group. */ public void setBlueGreenDeploymentConfiguration(BlueGreenDeploymentConfiguration blueGreenDeploymentConfiguration) { this.blueGreenDeploymentConfiguration = blueGreenDeploymentConfiguration; } /** *

* Information about blue/green deployment options for a deployment group. *

* * @return Information about blue/green deployment options for a deployment group. */ public BlueGreenDeploymentConfiguration getBlueGreenDeploymentConfiguration() { return this.blueGreenDeploymentConfiguration; } /** *

* Information about blue/green deployment options for a deployment group. *

* * @param blueGreenDeploymentConfiguration * Information about blue/green deployment options for a deployment group. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withBlueGreenDeploymentConfiguration(BlueGreenDeploymentConfiguration blueGreenDeploymentConfiguration) { setBlueGreenDeploymentConfiguration(blueGreenDeploymentConfiguration); return this; } /** *

* Information about the load balancer used in a deployment. *

* * @param loadBalancerInfo * Information about the load balancer used in a deployment. */ public void setLoadBalancerInfo(LoadBalancerInfo loadBalancerInfo) { this.loadBalancerInfo = loadBalancerInfo; } /** *

* Information about the load balancer used in a deployment. *

* * @return Information about the load balancer used in a deployment. */ public LoadBalancerInfo getLoadBalancerInfo() { return this.loadBalancerInfo; } /** *

* Information about the load balancer used in a deployment. *

* * @param loadBalancerInfo * Information about the load balancer used in a deployment. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withLoadBalancerInfo(LoadBalancerInfo loadBalancerInfo) { setLoadBalancerInfo(loadBalancerInfo); return this; } /** *

* Information about groups of tags applied to Amazon EC2 instances. The deployment group includes only Amazon EC2 * instances identified by all the tag groups. Cannot be used in the same call as ec2TagFilters. *

* * @param ec2TagSet * Information about groups of tags applied to Amazon EC2 instances. The deployment group includes only * Amazon EC2 instances identified by all the tag groups. Cannot be used in the same call as * ec2TagFilters. */ public void setEc2TagSet(EC2TagSet ec2TagSet) { this.ec2TagSet = ec2TagSet; } /** *

* Information about groups of tags applied to Amazon EC2 instances. The deployment group includes only Amazon EC2 * instances identified by all the tag groups. Cannot be used in the same call as ec2TagFilters. *

* * @return Information about groups of tags applied to Amazon EC2 instances. The deployment group includes only * Amazon EC2 instances identified by all the tag groups. Cannot be used in the same call as * ec2TagFilters. */ public EC2TagSet getEc2TagSet() { return this.ec2TagSet; } /** *

* Information about groups of tags applied to Amazon EC2 instances. The deployment group includes only Amazon EC2 * instances identified by all the tag groups. Cannot be used in the same call as ec2TagFilters. *

* * @param ec2TagSet * Information about groups of tags applied to Amazon EC2 instances. The deployment group includes only * Amazon EC2 instances identified by all the tag groups. Cannot be used in the same call as * ec2TagFilters. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withEc2TagSet(EC2TagSet ec2TagSet) { setEc2TagSet(ec2TagSet); return this; } /** *

* The target Amazon ECS services in the deployment group. This applies only to deployment groups that use the * Amazon ECS compute platform. A target Amazon ECS service is specified as an Amazon ECS cluster and service name * pair using the format <clustername>:<servicename>. *

* * @return The target Amazon ECS services in the deployment group. This applies only to deployment groups that use * the Amazon ECS compute platform. A target Amazon ECS service is specified as an Amazon ECS cluster and * service name pair using the format <clustername>:<servicename>. */ public java.util.List getEcsServices() { if (ecsServices == null) { ecsServices = new com.amazonaws.internal.SdkInternalList(); } return ecsServices; } /** *

* The target Amazon ECS services in the deployment group. This applies only to deployment groups that use the * Amazon ECS compute platform. A target Amazon ECS service is specified as an Amazon ECS cluster and service name * pair using the format <clustername>:<servicename>. *

* * @param ecsServices * The target Amazon ECS services in the deployment group. This applies only to deployment groups that use * the Amazon ECS compute platform. A target Amazon ECS service is specified as an Amazon ECS cluster and * service name pair using the format <clustername>:<servicename>. */ public void setEcsServices(java.util.Collection ecsServices) { if (ecsServices == null) { this.ecsServices = null; return; } this.ecsServices = new com.amazonaws.internal.SdkInternalList(ecsServices); } /** *

* The target Amazon ECS services in the deployment group. This applies only to deployment groups that use the * Amazon ECS compute platform. A target Amazon ECS service is specified as an Amazon ECS cluster and service name * pair using the format <clustername>:<servicename>. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setEcsServices(java.util.Collection)} or {@link #withEcsServices(java.util.Collection)} if you want to * override the existing values. *

* * @param ecsServices * The target Amazon ECS services in the deployment group. This applies only to deployment groups that use * the Amazon ECS compute platform. A target Amazon ECS service is specified as an Amazon ECS cluster and * service name pair using the format <clustername>:<servicename>. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withEcsServices(ECSService... ecsServices) { if (this.ecsServices == null) { setEcsServices(new com.amazonaws.internal.SdkInternalList(ecsServices.length)); } for (ECSService ele : ecsServices) { this.ecsServices.add(ele); } return this; } /** *

* The target Amazon ECS services in the deployment group. This applies only to deployment groups that use the * Amazon ECS compute platform. A target Amazon ECS service is specified as an Amazon ECS cluster and service name * pair using the format <clustername>:<servicename>. *

* * @param ecsServices * The target Amazon ECS services in the deployment group. This applies only to deployment groups that use * the Amazon ECS compute platform. A target Amazon ECS service is specified as an Amazon ECS cluster and * service name pair using the format <clustername>:<servicename>. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withEcsServices(java.util.Collection ecsServices) { setEcsServices(ecsServices); return this; } /** *

* Information about groups of tags applied to on-premises instances. The deployment group includes only on-premises * instances identified by all of the tag groups. Cannot be used in the same call as * onPremisesInstanceTagFilters. *

* * @param onPremisesTagSet * Information about groups of tags applied to on-premises instances. The deployment group includes only * on-premises instances identified by all of the tag groups. Cannot be used in the same call as * onPremisesInstanceTagFilters. */ public void setOnPremisesTagSet(OnPremisesTagSet onPremisesTagSet) { this.onPremisesTagSet = onPremisesTagSet; } /** *

* Information about groups of tags applied to on-premises instances. The deployment group includes only on-premises * instances identified by all of the tag groups. Cannot be used in the same call as * onPremisesInstanceTagFilters. *

* * @return Information about groups of tags applied to on-premises instances. The deployment group includes only * on-premises instances identified by all of the tag groups. Cannot be used in the same call as * onPremisesInstanceTagFilters. */ public OnPremisesTagSet getOnPremisesTagSet() { return this.onPremisesTagSet; } /** *

* Information about groups of tags applied to on-premises instances. The deployment group includes only on-premises * instances identified by all of the tag groups. Cannot be used in the same call as * onPremisesInstanceTagFilters. *

* * @param onPremisesTagSet * Information about groups of tags applied to on-premises instances. The deployment group includes only * on-premises instances identified by all of the tag groups. Cannot be used in the same call as * onPremisesInstanceTagFilters. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withOnPremisesTagSet(OnPremisesTagSet onPremisesTagSet) { setOnPremisesTagSet(onPremisesTagSet); return this; } /** *

* The metadata that you apply to CodeDeploy deployment groups to help you organize and categorize them. Each tag * consists of a key and an optional value, both of which you define. *

* * @return The metadata that you apply to CodeDeploy deployment groups to help you organize and categorize them. * Each tag consists of a key and an optional value, both of which you define. */ public java.util.List getTags() { if (tags == null) { tags = new com.amazonaws.internal.SdkInternalList(); } return tags; } /** *

* The metadata that you apply to CodeDeploy deployment groups to help you organize and categorize them. Each tag * consists of a key and an optional value, both of which you define. *

* * @param tags * The metadata that you apply to CodeDeploy deployment groups to help you organize and categorize them. Each * tag consists of a key and an optional value, both of which you define. */ public void setTags(java.util.Collection tags) { if (tags == null) { this.tags = null; return; } this.tags = new com.amazonaws.internal.SdkInternalList(tags); } /** *

* The metadata that you apply to CodeDeploy deployment groups to help you organize and categorize them. Each tag * consists of a key and an optional value, both of which you define. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setTags(java.util.Collection)} or {@link #withTags(java.util.Collection)} if you want to override the * existing values. *

* * @param tags * The metadata that you apply to CodeDeploy deployment groups to help you organize and categorize them. Each * tag consists of a key and an optional value, both of which you define. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withTags(Tag... tags) { if (this.tags == null) { setTags(new com.amazonaws.internal.SdkInternalList(tags.length)); } for (Tag ele : tags) { this.tags.add(ele); } return this; } /** *

* The metadata that you apply to CodeDeploy deployment groups to help you organize and categorize them. Each tag * consists of a key and an optional value, both of which you define. *

* * @param tags * The metadata that you apply to CodeDeploy deployment groups to help you organize and categorize them. Each * tag consists of a key and an optional value, both of which you define. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withTags(java.util.Collection tags) { setTags(tags); return this; } /** *

* This parameter only applies if you are using CodeDeploy with Amazon EC2 Auto Scaling. For more information, see * Integrating * CodeDeploy with Amazon EC2 Auto Scaling in the CodeDeploy User Guide. *

*

* Set terminationHookEnabled to true to have CodeDeploy install a termination hook into * your Auto Scaling group when you create a deployment group. When this hook is installed, CodeDeploy will perform * termination deployments. *

*

* For information about termination deployments, see Enabling termination deployments during Auto Scaling scale-in events in the CodeDeploy User Guide. *

*

* For more information about Auto Scaling scale-in events, see the Scale in topic in the Amazon EC2 Auto Scaling User Guide. *

* * @param terminationHookEnabled * This parameter only applies if you are using CodeDeploy with Amazon EC2 Auto Scaling. For more * information, see Integrating CodeDeploy with Amazon EC2 Auto Scaling in the CodeDeploy User Guide.

*

* Set terminationHookEnabled to true to have CodeDeploy install a termination hook * into your Auto Scaling group when you create a deployment group. When this hook is installed, CodeDeploy * will perform termination deployments. *

*

* For information about termination deployments, see Enabling termination deployments during Auto Scaling scale-in events in the CodeDeploy User * Guide. *

*

* For more information about Auto Scaling scale-in events, see the Scale in topic in the Amazon EC2 Auto Scaling User Guide. */ public void setTerminationHookEnabled(Boolean terminationHookEnabled) { this.terminationHookEnabled = terminationHookEnabled; } /** *

* This parameter only applies if you are using CodeDeploy with Amazon EC2 Auto Scaling. For more information, see * Integrating * CodeDeploy with Amazon EC2 Auto Scaling in the CodeDeploy User Guide. *

*

* Set terminationHookEnabled to true to have CodeDeploy install a termination hook into * your Auto Scaling group when you create a deployment group. When this hook is installed, CodeDeploy will perform * termination deployments. *

*

* For information about termination deployments, see Enabling termination deployments during Auto Scaling scale-in events in the CodeDeploy User Guide. *

*

* For more information about Auto Scaling scale-in events, see the Scale in topic in the Amazon EC2 Auto Scaling User Guide. *

* * @return This parameter only applies if you are using CodeDeploy with Amazon EC2 Auto Scaling. For more * information, see Integrating CodeDeploy with Amazon EC2 Auto Scaling in the CodeDeploy User Guide.

*

* Set terminationHookEnabled to true to have CodeDeploy install a termination * hook into your Auto Scaling group when you create a deployment group. When this hook is installed, * CodeDeploy will perform termination deployments. *

*

* For information about termination deployments, see Enabling termination deployments during Auto Scaling scale-in events in the CodeDeploy User * Guide. *

*

* For more information about Auto Scaling scale-in events, see the Scale in topic in the Amazon EC2 Auto Scaling User Guide. */ public Boolean getTerminationHookEnabled() { return this.terminationHookEnabled; } /** *

* This parameter only applies if you are using CodeDeploy with Amazon EC2 Auto Scaling. For more information, see * Integrating * CodeDeploy with Amazon EC2 Auto Scaling in the CodeDeploy User Guide. *

*

* Set terminationHookEnabled to true to have CodeDeploy install a termination hook into * your Auto Scaling group when you create a deployment group. When this hook is installed, CodeDeploy will perform * termination deployments. *

*

* For information about termination deployments, see Enabling termination deployments during Auto Scaling scale-in events in the CodeDeploy User Guide. *

*

* For more information about Auto Scaling scale-in events, see the Scale in topic in the Amazon EC2 Auto Scaling User Guide. *

* * @param terminationHookEnabled * This parameter only applies if you are using CodeDeploy with Amazon EC2 Auto Scaling. For more * information, see Integrating CodeDeploy with Amazon EC2 Auto Scaling in the CodeDeploy User Guide.

*

* Set terminationHookEnabled to true to have CodeDeploy install a termination hook * into your Auto Scaling group when you create a deployment group. When this hook is installed, CodeDeploy * will perform termination deployments. *

*

* For information about termination deployments, see Enabling termination deployments during Auto Scaling scale-in events in the CodeDeploy User * Guide. *

*

* For more information about Auto Scaling scale-in events, see the Scale in topic in the Amazon EC2 Auto Scaling User Guide. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateDeploymentGroupRequest withTerminationHookEnabled(Boolean terminationHookEnabled) { setTerminationHookEnabled(terminationHookEnabled); return this; } /** *

* This parameter only applies if you are using CodeDeploy with Amazon EC2 Auto Scaling. For more information, see * Integrating * CodeDeploy with Amazon EC2 Auto Scaling in the CodeDeploy User Guide. *

*

* Set terminationHookEnabled to true to have CodeDeploy install a termination hook into * your Auto Scaling group when you create a deployment group. When this hook is installed, CodeDeploy will perform * termination deployments. *

*

* For information about termination deployments, see Enabling termination deployments during Auto Scaling scale-in events in the CodeDeploy User Guide. *

*

* For more information about Auto Scaling scale-in events, see the Scale in topic in the Amazon EC2 Auto Scaling User Guide. *

* * @return This parameter only applies if you are using CodeDeploy with Amazon EC2 Auto Scaling. For more * information, see Integrating CodeDeploy with Amazon EC2 Auto Scaling in the CodeDeploy User Guide.

*

* Set terminationHookEnabled to true to have CodeDeploy install a termination * hook into your Auto Scaling group when you create a deployment group. When this hook is installed, * CodeDeploy will perform termination deployments. *

*

* For information about termination deployments, see Enabling termination deployments during Auto Scaling scale-in events in the CodeDeploy User * Guide. *

*

* For more information about Auto Scaling scale-in events, see the Scale in topic in the Amazon EC2 Auto Scaling User Guide. */ public Boolean isTerminationHookEnabled() { return this.terminationHookEnabled; } /** * 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 (getApplicationName() != null) sb.append("ApplicationName: ").append(getApplicationName()).append(","); if (getDeploymentGroupName() != null) sb.append("DeploymentGroupName: ").append(getDeploymentGroupName()).append(","); if (getDeploymentConfigName() != null) sb.append("DeploymentConfigName: ").append(getDeploymentConfigName()).append(","); if (getEc2TagFilters() != null) sb.append("Ec2TagFilters: ").append(getEc2TagFilters()).append(","); if (getOnPremisesInstanceTagFilters() != null) sb.append("OnPremisesInstanceTagFilters: ").append(getOnPremisesInstanceTagFilters()).append(","); if (getAutoScalingGroups() != null) sb.append("AutoScalingGroups: ").append(getAutoScalingGroups()).append(","); if (getServiceRoleArn() != null) sb.append("ServiceRoleArn: ").append(getServiceRoleArn()).append(","); if (getTriggerConfigurations() != null) sb.append("TriggerConfigurations: ").append(getTriggerConfigurations()).append(","); if (getAlarmConfiguration() != null) sb.append("AlarmConfiguration: ").append(getAlarmConfiguration()).append(","); if (getAutoRollbackConfiguration() != null) sb.append("AutoRollbackConfiguration: ").append(getAutoRollbackConfiguration()).append(","); if (getOutdatedInstancesStrategy() != null) sb.append("OutdatedInstancesStrategy: ").append(getOutdatedInstancesStrategy()).append(","); if (getDeploymentStyle() != null) sb.append("DeploymentStyle: ").append(getDeploymentStyle()).append(","); if (getBlueGreenDeploymentConfiguration() != null) sb.append("BlueGreenDeploymentConfiguration: ").append(getBlueGreenDeploymentConfiguration()).append(","); if (getLoadBalancerInfo() != null) sb.append("LoadBalancerInfo: ").append(getLoadBalancerInfo()).append(","); if (getEc2TagSet() != null) sb.append("Ec2TagSet: ").append(getEc2TagSet()).append(","); if (getEcsServices() != null) sb.append("EcsServices: ").append(getEcsServices()).append(","); if (getOnPremisesTagSet() != null) sb.append("OnPremisesTagSet: ").append(getOnPremisesTagSet()).append(","); if (getTags() != null) sb.append("Tags: ").append(getTags()).append(","); if (getTerminationHookEnabled() != null) sb.append("TerminationHookEnabled: ").append(getTerminationHookEnabled()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof CreateDeploymentGroupRequest == false) return false; CreateDeploymentGroupRequest other = (CreateDeploymentGroupRequest) obj; if (other.getApplicationName() == null ^ this.getApplicationName() == null) return false; if (other.getApplicationName() != null && other.getApplicationName().equals(this.getApplicationName()) == false) return false; if (other.getDeploymentGroupName() == null ^ this.getDeploymentGroupName() == null) return false; if (other.getDeploymentGroupName() != null && other.getDeploymentGroupName().equals(this.getDeploymentGroupName()) == false) return false; if (other.getDeploymentConfigName() == null ^ this.getDeploymentConfigName() == null) return false; if (other.getDeploymentConfigName() != null && other.getDeploymentConfigName().equals(this.getDeploymentConfigName()) == false) return false; if (other.getEc2TagFilters() == null ^ this.getEc2TagFilters() == null) return false; if (other.getEc2TagFilters() != null && other.getEc2TagFilters().equals(this.getEc2TagFilters()) == false) return false; if (other.getOnPremisesInstanceTagFilters() == null ^ this.getOnPremisesInstanceTagFilters() == null) return false; if (other.getOnPremisesInstanceTagFilters() != null && other.getOnPremisesInstanceTagFilters().equals(this.getOnPremisesInstanceTagFilters()) == false) return false; if (other.getAutoScalingGroups() == null ^ this.getAutoScalingGroups() == null) return false; if (other.getAutoScalingGroups() != null && other.getAutoScalingGroups().equals(this.getAutoScalingGroups()) == false) return false; if (other.getServiceRoleArn() == null ^ this.getServiceRoleArn() == null) return false; if (other.getServiceRoleArn() != null && other.getServiceRoleArn().equals(this.getServiceRoleArn()) == false) return false; if (other.getTriggerConfigurations() == null ^ this.getTriggerConfigurations() == null) return false; if (other.getTriggerConfigurations() != null && other.getTriggerConfigurations().equals(this.getTriggerConfigurations()) == false) return false; if (other.getAlarmConfiguration() == null ^ this.getAlarmConfiguration() == null) return false; if (other.getAlarmConfiguration() != null && other.getAlarmConfiguration().equals(this.getAlarmConfiguration()) == false) return false; if (other.getAutoRollbackConfiguration() == null ^ this.getAutoRollbackConfiguration() == null) return false; if (other.getAutoRollbackConfiguration() != null && other.getAutoRollbackConfiguration().equals(this.getAutoRollbackConfiguration()) == false) return false; if (other.getOutdatedInstancesStrategy() == null ^ this.getOutdatedInstancesStrategy() == null) return false; if (other.getOutdatedInstancesStrategy() != null && other.getOutdatedInstancesStrategy().equals(this.getOutdatedInstancesStrategy()) == false) return false; if (other.getDeploymentStyle() == null ^ this.getDeploymentStyle() == null) return false; if (other.getDeploymentStyle() != null && other.getDeploymentStyle().equals(this.getDeploymentStyle()) == false) return false; if (other.getBlueGreenDeploymentConfiguration() == null ^ this.getBlueGreenDeploymentConfiguration() == null) return false; if (other.getBlueGreenDeploymentConfiguration() != null && other.getBlueGreenDeploymentConfiguration().equals(this.getBlueGreenDeploymentConfiguration()) == false) return false; if (other.getLoadBalancerInfo() == null ^ this.getLoadBalancerInfo() == null) return false; if (other.getLoadBalancerInfo() != null && other.getLoadBalancerInfo().equals(this.getLoadBalancerInfo()) == false) return false; if (other.getEc2TagSet() == null ^ this.getEc2TagSet() == null) return false; if (other.getEc2TagSet() != null && other.getEc2TagSet().equals(this.getEc2TagSet()) == false) return false; if (other.getEcsServices() == null ^ this.getEcsServices() == null) return false; if (other.getEcsServices() != null && other.getEcsServices().equals(this.getEcsServices()) == false) return false; if (other.getOnPremisesTagSet() == null ^ this.getOnPremisesTagSet() == null) return false; if (other.getOnPremisesTagSet() != null && other.getOnPremisesTagSet().equals(this.getOnPremisesTagSet()) == false) return false; if (other.getTags() == null ^ this.getTags() == null) return false; if (other.getTags() != null && other.getTags().equals(this.getTags()) == false) return false; if (other.getTerminationHookEnabled() == null ^ this.getTerminationHookEnabled() == null) return false; if (other.getTerminationHookEnabled() != null && other.getTerminationHookEnabled().equals(this.getTerminationHookEnabled()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getApplicationName() == null) ? 0 : getApplicationName().hashCode()); hashCode = prime * hashCode + ((getDeploymentGroupName() == null) ? 0 : getDeploymentGroupName().hashCode()); hashCode = prime * hashCode + ((getDeploymentConfigName() == null) ? 0 : getDeploymentConfigName().hashCode()); hashCode = prime * hashCode + ((getEc2TagFilters() == null) ? 0 : getEc2TagFilters().hashCode()); hashCode = prime * hashCode + ((getOnPremisesInstanceTagFilters() == null) ? 0 : getOnPremisesInstanceTagFilters().hashCode()); hashCode = prime * hashCode + ((getAutoScalingGroups() == null) ? 0 : getAutoScalingGroups().hashCode()); hashCode = prime * hashCode + ((getServiceRoleArn() == null) ? 0 : getServiceRoleArn().hashCode()); hashCode = prime * hashCode + ((getTriggerConfigurations() == null) ? 0 : getTriggerConfigurations().hashCode()); hashCode = prime * hashCode + ((getAlarmConfiguration() == null) ? 0 : getAlarmConfiguration().hashCode()); hashCode = prime * hashCode + ((getAutoRollbackConfiguration() == null) ? 0 : getAutoRollbackConfiguration().hashCode()); hashCode = prime * hashCode + ((getOutdatedInstancesStrategy() == null) ? 0 : getOutdatedInstancesStrategy().hashCode()); hashCode = prime * hashCode + ((getDeploymentStyle() == null) ? 0 : getDeploymentStyle().hashCode()); hashCode = prime * hashCode + ((getBlueGreenDeploymentConfiguration() == null) ? 0 : getBlueGreenDeploymentConfiguration().hashCode()); hashCode = prime * hashCode + ((getLoadBalancerInfo() == null) ? 0 : getLoadBalancerInfo().hashCode()); hashCode = prime * hashCode + ((getEc2TagSet() == null) ? 0 : getEc2TagSet().hashCode()); hashCode = prime * hashCode + ((getEcsServices() == null) ? 0 : getEcsServices().hashCode()); hashCode = prime * hashCode + ((getOnPremisesTagSet() == null) ? 0 : getOnPremisesTagSet().hashCode()); hashCode = prime * hashCode + ((getTags() == null) ? 0 : getTags().hashCode()); hashCode = prime * hashCode + ((getTerminationHookEnabled() == null) ? 0 : getTerminationHookEnabled().hashCode()); return hashCode; } @Override public CreateDeploymentGroupRequest clone() { return (CreateDeploymentGroupRequest) super.clone(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy