// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
impl super::Client {
/// Constructs a fluent builder for the [`UpdateDeploymentGroup`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder) operation.
///
/// - The fluent builder is configurable:
/// - [`application_name(impl Into<String>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::application_name) / [`set_application_name(Option<String>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::set_application_name):<br>required: **true**<br><p>The application name that corresponds to the deployment group to update.</p><br>
/// - [`current_deployment_group_name(impl Into<String>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::current_deployment_group_name) / [`set_current_deployment_group_name(Option<String>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::set_current_deployment_group_name):<br>required: **true**<br><p>The current name of the deployment group.</p><br>
/// - [`new_deployment_group_name(impl Into<String>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::new_deployment_group_name) / [`set_new_deployment_group_name(Option<String>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::set_new_deployment_group_name):<br>required: **false**<br><p>The new name of the deployment group, if you want to change it.</p><br>
/// - [`deployment_config_name(impl Into<String>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::deployment_config_name) / [`set_deployment_config_name(Option<String>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::set_deployment_config_name):<br>required: **false**<br><p>The replacement deployment configuration name to use, if you want to change it.</p><br>
/// - [`ec2_tag_filters(Ec2TagFilter)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::ec2_tag_filters) / [`set_ec2_tag_filters(Option<Vec::<Ec2TagFilter>>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::set_ec2_tag_filters):<br>required: **false**<br><p>The replacement set of Amazon EC2 tags on which to filter, if you want to change them. To keep the existing tags, enter their names. To remove tags, do not enter any tag names.</p><br>
/// - [`on_premises_instance_tag_filters(TagFilter)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::on_premises_instance_tag_filters) / [`set_on_premises_instance_tag_filters(Option<Vec::<TagFilter>>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::set_on_premises_instance_tag_filters):<br>required: **false**<br><p>The replacement set of on-premises instance tags on which to filter, if you want to change them. To keep the existing tags, enter their names. To remove tags, do not enter any tag names.</p><br>
/// - [`auto_scaling_groups(impl Into<String>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::auto_scaling_groups) / [`set_auto_scaling_groups(Option<Vec::<String>>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::set_auto_scaling_groups):<br>required: **false**<br><p>The replacement list of Auto Scaling groups to be included in the deployment group, if you want to change them.</p> <ul> <li> <p>To keep the Auto Scaling groups, enter their names or do not specify this parameter. </p> </li> <li> <p>To remove Auto Scaling groups, specify a non-null empty list of Auto Scaling group names to detach all CodeDeploy-managed Auto Scaling lifecycle hooks. For examples, see <a href="https://docs.aws.amazon.com/codedeploy/latest/userguide/troubleshooting-auto-scaling.html#troubleshooting-auto-scaling-heartbeat">Amazon EC2 instances in an Amazon EC2 Auto Scaling group fail to launch and receive the error "Heartbeat Timeout"</a> in the <i>CodeDeploy User Guide</i>.</p> </li> </ul><br>
/// - [`service_role_arn(impl Into<String>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::service_role_arn) / [`set_service_role_arn(Option<String>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::set_service_role_arn):<br>required: **false**<br><p>A replacement ARN for the service role, if you want to change it.</p><br>
/// - [`trigger_configurations(TriggerConfig)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::trigger_configurations) / [`set_trigger_configurations(Option<Vec::<TriggerConfig>>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::set_trigger_configurations):<br>required: **false**<br><p>Information about triggers to change when the deployment group is updated. For examples, see <a href="https://docs.aws.amazon.com/codedeploy/latest/userguide/how-to-notify-edit.html">Edit a Trigger in a CodeDeploy Deployment Group</a> in the <i>CodeDeploy User Guide</i>.</p><br>
/// - [`alarm_configuration(AlarmConfiguration)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::alarm_configuration) / [`set_alarm_configuration(Option<AlarmConfiguration>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::set_alarm_configuration):<br>required: **false**<br><p>Information to add or change about Amazon CloudWatch alarms when the deployment group is updated.</p><br>
/// - [`auto_rollback_configuration(AutoRollbackConfiguration)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::auto_rollback_configuration) / [`set_auto_rollback_configuration(Option<AutoRollbackConfiguration>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::set_auto_rollback_configuration):<br>required: **false**<br><p>Information for an automatic rollback configuration that is added or changed when a deployment group is updated.</p><br>
/// - [`outdated_instances_strategy(OutdatedInstancesStrategy)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::outdated_instances_strategy) / [`set_outdated_instances_strategy(Option<OutdatedInstancesStrategy>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::set_outdated_instances_strategy):<br>required: **false**<br><p>Indicates what happens when new Amazon EC2 instances are launched mid-deployment and do not receive the deployed application revision.</p> <p>If this option is set to <code>UPDATE</code> 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.</p> <p>If this option is set to <code>IGNORE</code>, CodeDeploy does not initiate a deployment to update the new Amazon EC2 instances. This may result in instances having different revisions.</p><br>
/// - [`deployment_style(DeploymentStyle)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::deployment_style) / [`set_deployment_style(Option<DeploymentStyle>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::set_deployment_style):<br>required: **false**<br><p>Information about the type of deployment, either in-place or blue/green, you want to run and whether to route deployment traffic behind a load balancer.</p><br>
/// - [`blue_green_deployment_configuration(BlueGreenDeploymentConfiguration)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::blue_green_deployment_configuration) / [`set_blue_green_deployment_configuration(Option<BlueGreenDeploymentConfiguration>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::set_blue_green_deployment_configuration):<br>required: **false**<br><p>Information about blue/green deployment options for a deployment group.</p><br>
/// - [`load_balancer_info(LoadBalancerInfo)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::load_balancer_info) / [`set_load_balancer_info(Option<LoadBalancerInfo>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::set_load_balancer_info):<br>required: **false**<br><p>Information about the load balancer used in a deployment.</p><br>
/// - [`ec2_tag_set(Ec2TagSet)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::ec2_tag_set) / [`set_ec2_tag_set(Option<Ec2TagSet>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::set_ec2_tag_set):<br>required: **false**<br><p>Information about groups of tags applied to on-premises instances. The deployment group includes only Amazon EC2 instances identified by all the tag groups.</p><br>
/// - [`ecs_services(EcsService)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::ecs_services) / [`set_ecs_services(Option<Vec::<EcsService>>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::set_ecs_services):<br>required: **false**<br><p> 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 <code> <clustername> : <servicename></servicename> </clustername></code>. </p><br>
/// - [`on_premises_tag_set(OnPremisesTagSet)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::on_premises_tag_set) / [`set_on_premises_tag_set(Option<OnPremisesTagSet>)`](crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::set_on_premises_tag_set):<br>required: **false**<br><p>Information about an on-premises instance tag set. The deployment group includes only on-premises instances identified by all the tag groups.</p><br>
/// - On success, responds with [`UpdateDeploymentGroupOutput`](crate::operation::update_deployment_group::UpdateDeploymentGroupOutput) with field(s):
/// - [`hooks_not_cleaned_up(Option<Vec::<AutoScalingGroup>>)`](crate::operation::update_deployment_group::UpdateDeploymentGroupOutput::hooks_not_cleaned_up): <p>If the output contains no data, and the corresponding deployment group contained at least one Auto Scaling group, CodeDeploy successfully removed all corresponding Auto Scaling lifecycle event hooks from the Amazon Web Services account. If the output contains data, CodeDeploy could not remove some Auto Scaling lifecycle event hooks from the Amazon Web Services account.</p>
/// - On failure, responds with [`SdkError<UpdateDeploymentGroupError>`](crate::operation::update_deployment_group::UpdateDeploymentGroupError)
pub fn update_deployment_group(&self) -> crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder {
crate::operation::update_deployment_group::builders::UpdateDeploymentGroupFluentBuilder::new(self.handle.clone())
}
}