// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
impl super::Client {
    /// Constructs a fluent builder for the [`UpdateUser`](crate::operation::update_user::builders::UpdateUserFluentBuilder) operation.
    ///
    /// - The fluent builder is configurable:
    ///   - [`user_name(impl Into<String>)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::user_name) / [`set_user_name(Option<String>)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::set_user_name):<br>required: **true**<br><p>The Amazon QuickSight user name that you want to update.</p><br>
    ///   - [`aws_account_id(impl Into<String>)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::aws_account_id) / [`set_aws_account_id(Option<String>)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::set_aws_account_id):<br>required: **true**<br><p>The ID for the Amazon Web Services account that the user is in. Currently, you use the ID for the Amazon Web Services account that contains your Amazon QuickSight account.</p><br>
    ///   - [`namespace(impl Into<String>)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::namespace) / [`set_namespace(Option<String>)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::set_namespace):<br>required: **true**<br><p>The namespace. Currently, you should set this to <code>default</code>.</p><br>
    ///   - [`email(impl Into<String>)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::email) / [`set_email(Option<String>)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::set_email):<br>required: **true**<br><p>The email address of the user that you want to update.</p><br>
    ///   - [`role(UserRole)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::role) / [`set_role(Option<UserRole>)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::set_role):<br>required: **true**<br><p>The Amazon QuickSight role of the user. The role can be one of the following default security cohorts:</p>  <ul>   <li> <p> <code>READER</code>: A user who has read-only access to dashboards.</p> </li>   <li> <p> <code>AUTHOR</code>: A user who can create data sources, datasets, analyses, and dashboards.</p> </li>   <li> <p> <code>ADMIN</code>: A user who is an author, who can also manage Amazon QuickSight settings.</p> </li>  </ul>  <p>The name of the Amazon QuickSight role is invisible to the user except for the console screens dealing with permissions.</p><br>
    ///   - [`custom_permissions_name(impl Into<String>)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::custom_permissions_name) / [`set_custom_permissions_name(Option<String>)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::set_custom_permissions_name):<br>required: **false**<br><p>(Enterprise edition only) The name of the custom permissions profile that you want to assign to this user. Customized permissions allows you to control a user's access by restricting access the following operations:</p>  <ul>   <li> <p>Create and update data sources</p> </li>   <li> <p>Create and update datasets</p> </li>   <li> <p>Create and update email reports</p> </li>   <li> <p>Subscribe to email reports</p> </li>  </ul>  <p>A set of custom permissions includes any combination of these restrictions. Currently, you need to create the profile names for custom permission sets by using the Amazon QuickSight console. Then, you use the <code>RegisterUser</code> API operation to assign the named set of permissions to a Amazon QuickSight user. </p>  <p>Amazon QuickSight custom permissions are applied through IAM policies. Therefore, they override the permissions typically granted by assigning Amazon QuickSight users to one of the default security cohorts in Amazon QuickSight (admin, author, reader).</p>  <p>This feature is available only to Amazon QuickSight Enterprise edition subscriptions.</p><br>
    ///   - [`unapply_custom_permissions(bool)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::unapply_custom_permissions) / [`set_unapply_custom_permissions(Option<bool>)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::set_unapply_custom_permissions):<br>required: **false**<br><p>A flag that you use to indicate that you want to remove all custom permissions from this user. Using this parameter resets the user to the state it was in before a custom permissions profile was applied. This parameter defaults to NULL and it doesn't accept any other value.</p><br>
    ///   - [`external_login_federation_provider_type(impl Into<String>)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::external_login_federation_provider_type) / [`set_external_login_federation_provider_type(Option<String>)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::set_external_login_federation_provider_type):<br>required: **false**<br><p>The type of supported external login provider that provides identity to let a user federate into Amazon QuickSight with an associated Identity and Access Management(IAM) role. The type of supported external login provider can be one of the following.</p>  <ul>   <li> <p> <code>COGNITO</code>: Amazon Cognito. The provider URL is cognito-identity.amazonaws.com. When choosing the <code>COGNITO</code> provider type, don’t use the "CustomFederationProviderUrl" parameter which is only needed when the external provider is custom.</p> </li>   <li> <p> <code>CUSTOM_OIDC</code>: Custom OpenID Connect (OIDC) provider. When choosing <code>CUSTOM_OIDC</code> type, use the <code>CustomFederationProviderUrl</code> parameter to provide the custom OIDC provider URL.</p> </li>   <li> <p> <code>NONE</code>: This clears all the previously saved external login information for a user. Use the <code> <a href="https://docs.aws.amazon.com/quicksight/latest/APIReference/API_DescribeUser.html">DescribeUser</a> </code> API operation to check the external login information.</p> </li>  </ul><br>
    ///   - [`custom_federation_provider_url(impl Into<String>)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::custom_federation_provider_url) / [`set_custom_federation_provider_url(Option<String>)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::set_custom_federation_provider_url):<br>required: **false**<br><p>The URL of the custom OpenID Connect (OIDC) provider that provides identity to let a user federate into Amazon QuickSight with an associated Identity and Access Management(IAM) role. This parameter should only be used when <code>ExternalLoginFederationProviderType</code> parameter is set to <code>CUSTOM_OIDC</code>.</p><br>
    ///   - [`external_login_id(impl Into<String>)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::external_login_id) / [`set_external_login_id(Option<String>)`](crate::operation::update_user::builders::UpdateUserFluentBuilder::set_external_login_id):<br>required: **false**<br><p>The identity ID for a user in the external login provider.</p><br>
    /// - On success, responds with [`UpdateUserOutput`](crate::operation::update_user::UpdateUserOutput) with field(s):
    ///   - [`user(Option<User>)`](crate::operation::update_user::UpdateUserOutput::user): <p>The Amazon QuickSight user.</p>
    ///   - [`request_id(Option<String>)`](crate::operation::update_user::UpdateUserOutput::request_id): <p>The Amazon Web Services request ID for this operation.</p>
    ///   - [`status(i32)`](crate::operation::update_user::UpdateUserOutput::status): <p>The HTTP status of the request.</p>
    /// - On failure, responds with [`SdkError<UpdateUserError>`](crate::operation::update_user::UpdateUserError)
    pub fn update_user(&self) -> crate::operation::update_user::builders::UpdateUserFluentBuilder {
        crate::operation::update_user::builders::UpdateUserFluentBuilder::new(self.handle.clone())
    }
}