// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
impl super::Client {
    /// Constructs a fluent builder for the [`UpdateFirewallRuleGroupAssociation`](crate::operation::update_firewall_rule_group_association::builders::UpdateFirewallRuleGroupAssociationFluentBuilder) operation.
    ///
    /// - The fluent builder is configurable:
    ///   - [`firewall_rule_group_association_id(impl Into<String>)`](crate::operation::update_firewall_rule_group_association::builders::UpdateFirewallRuleGroupAssociationFluentBuilder::firewall_rule_group_association_id) / [`set_firewall_rule_group_association_id(Option<String>)`](crate::operation::update_firewall_rule_group_association::builders::UpdateFirewallRuleGroupAssociationFluentBuilder::set_firewall_rule_group_association_id):<br>required: **true**<br><p>The identifier of the <code>FirewallRuleGroupAssociation</code>.</p><br>
    ///   - [`priority(i32)`](crate::operation::update_firewall_rule_group_association::builders::UpdateFirewallRuleGroupAssociationFluentBuilder::priority) / [`set_priority(Option<i32>)`](crate::operation::update_firewall_rule_group_association::builders::UpdateFirewallRuleGroupAssociationFluentBuilder::set_priority):<br>required: **false**<br><p>The setting that determines the processing order of the rule group among the rule groups that you associate with the specified VPC. DNS Firewall filters VPC traffic starting from the rule group with the lowest numeric priority setting.</p> <p>You must specify a unique priority for each rule group that you associate with a single VPC. To make it easier to insert rule groups later, leave space between the numbers, for example, use 100, 200, and so on. You can change the priority setting for a rule group association after you create it.</p><br>
    ///   - [`mutation_protection(MutationProtectionStatus)`](crate::operation::update_firewall_rule_group_association::builders::UpdateFirewallRuleGroupAssociationFluentBuilder::mutation_protection) / [`set_mutation_protection(Option<MutationProtectionStatus>)`](crate::operation::update_firewall_rule_group_association::builders::UpdateFirewallRuleGroupAssociationFluentBuilder::set_mutation_protection):<br>required: **false**<br><p>If enabled, this setting disallows modification or removal of the association, to help prevent against accidentally altering DNS firewall protections.</p><br>
    ///   - [`name(impl Into<String>)`](crate::operation::update_firewall_rule_group_association::builders::UpdateFirewallRuleGroupAssociationFluentBuilder::name) / [`set_name(Option<String>)`](crate::operation::update_firewall_rule_group_association::builders::UpdateFirewallRuleGroupAssociationFluentBuilder::set_name):<br>required: **false**<br><p>The name of the rule group association.</p><br>
    /// - On success, responds with [`UpdateFirewallRuleGroupAssociationOutput`](crate::operation::update_firewall_rule_group_association::UpdateFirewallRuleGroupAssociationOutput) with field(s):
    ///   - [`firewall_rule_group_association(Option<FirewallRuleGroupAssociation>)`](crate::operation::update_firewall_rule_group_association::UpdateFirewallRuleGroupAssociationOutput::firewall_rule_group_association): <p>The association that you just updated.</p>
    /// - On failure, responds with [`SdkError<UpdateFirewallRuleGroupAssociationError>`](crate::operation::update_firewall_rule_group_association::UpdateFirewallRuleGroupAssociationError)
    pub fn update_firewall_rule_group_association(
        &self,
    ) -> crate::operation::update_firewall_rule_group_association::builders::UpdateFirewallRuleGroupAssociationFluentBuilder {
        crate::operation::update_firewall_rule_group_association::builders::UpdateFirewallRuleGroupAssociationFluentBuilder::new(self.handle.clone())
    }
}