// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
impl super::Client {
    /// Constructs a fluent builder for the [`UnlockRule`](crate::operation::unlock_rule::builders::UnlockRuleFluentBuilder) operation.
    ///
    /// - The fluent builder is configurable:
    ///   - [`identifier(impl Into<String>)`](crate::operation::unlock_rule::builders::UnlockRuleFluentBuilder::identifier) / [`set_identifier(Option<String>)`](crate::operation::unlock_rule::builders::UnlockRuleFluentBuilder::set_identifier): <p>The unique ID of the retention rule.</p>
    /// - On success, responds with [`UnlockRuleOutput`](crate::operation::unlock_rule::UnlockRuleOutput) with field(s):
    ///   - [`identifier(Option<String>)`](crate::operation::unlock_rule::UnlockRuleOutput::identifier): <p>The unique ID of the retention rule.</p>
    ///   - [`description(Option<String>)`](crate::operation::unlock_rule::UnlockRuleOutput::description): <p>The retention rule description.</p>
    ///   - [`resource_type(Option<ResourceType>)`](crate::operation::unlock_rule::UnlockRuleOutput::resource_type): <p>The resource type retained by the retention rule.</p>
    ///   - [`retention_period(Option<RetentionPeriod>)`](crate::operation::unlock_rule::UnlockRuleOutput::retention_period): <p>Information about the retention period for which the retention rule is to retain resources.</p>
    ///   - [`resource_tags(Option<Vec<ResourceTag>>)`](crate::operation::unlock_rule::UnlockRuleOutput::resource_tags): <p>Information about the resource tags used to identify resources that are retained by the retention rule.</p>
    ///   - [`status(Option<RuleStatus>)`](crate::operation::unlock_rule::UnlockRuleOutput::status): <p>The state of the retention rule. Only retention rules that are in the <code>available</code> state retain resources.</p>
    ///   - [`lock_configuration(Option<LockConfiguration>)`](crate::operation::unlock_rule::UnlockRuleOutput::lock_configuration): <p>Information about the retention rule lock configuration.</p>
    ///   - [`lock_state(Option<LockState>)`](crate::operation::unlock_rule::UnlockRuleOutput::lock_state): <p>The lock state for the retention rule.</p>  <ul>   <li> <p> <code>locked</code> - The retention rule is locked and can't be modified or deleted.</p> </li>   <li> <p> <code>pending_unlock</code> - The retention rule has been unlocked but it is still within the unlock delay period. The retention rule can be modified or deleted only after the unlock delay period has expired.</p> </li>   <li> <p> <code>unlocked</code> - The retention rule is unlocked and it can be modified or deleted by any user with the required permissions.</p> </li>   <li> <p> <code>null</code> - The retention rule has never been locked. Once a retention rule has been locked, it can transition between the <code>locked</code> and <code>unlocked</code> states only; it can never transition back to <code>null</code>.</p> </li>  </ul>
    ///   - [`lock_end_time(Option<DateTime>)`](crate::operation::unlock_rule::UnlockRuleOutput::lock_end_time): <p>The date and time at which the unlock delay is set to expire. Only returned for retention rules that have been unlocked and that are still within the unlock delay period.</p>
    /// - On failure, responds with [`SdkError<UnlockRuleError>`](crate::operation::unlock_rule::UnlockRuleError)
    pub fn unlock_rule(&self) -> crate::operation::unlock_rule::builders::UnlockRuleFluentBuilder {
        crate::operation::unlock_rule::builders::UnlockRuleFluentBuilder::new(self.handle.clone())
    }
}