{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE NamedFieldPuns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE NoImplicitPrelude #-} {-# OPTIONS_GHC -fno-warn-unused-binds #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Amazonka.CognitoIdentityProvider.AdminSetUserMFAPreference -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- The user\'s multi-factor authentication (MFA) preference, including -- which MFA options are activated, and if any are preferred. Only one -- factor can be set as preferred. The preferred MFA factor will be used to -- authenticate a user if multiple factors are activated. If multiple -- options are activated and no preference is set, a challenge to choose an -- MFA option will be returned during sign-in. module Amazonka.CognitoIdentityProvider.AdminSetUserMFAPreference ( -- * Creating a Request AdminSetUserMFAPreference (..), newAdminSetUserMFAPreference, -- * Request Lenses adminSetUserMFAPreference_sMSMfaSettings, adminSetUserMFAPreference_softwareTokenMfaSettings, adminSetUserMFAPreference_username, adminSetUserMFAPreference_userPoolId, -- * Destructuring the Response AdminSetUserMFAPreferenceResponse (..), newAdminSetUserMFAPreferenceResponse, -- * Response Lenses adminSetUserMFAPreferenceResponse_httpStatus, ) where import Amazonka.CognitoIdentityProvider.Types import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newAdminSetUserMFAPreference' smart constructor. data AdminSetUserMFAPreference = AdminSetUserMFAPreference' { -- | The SMS text message MFA settings. sMSMfaSettings :: Prelude.Maybe SMSMfaSettingsType, -- | The time-based one-time password software token MFA settings. softwareTokenMfaSettings :: Prelude.Maybe SoftwareTokenMfaSettingsType, -- | The user pool username or alias. username :: Data.Sensitive Prelude.Text, -- | The user pool ID. userPoolId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'AdminSetUserMFAPreference' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'sMSMfaSettings', 'adminSetUserMFAPreference_sMSMfaSettings' - The SMS text message MFA settings. -- -- 'softwareTokenMfaSettings', 'adminSetUserMFAPreference_softwareTokenMfaSettings' - The time-based one-time password software token MFA settings. -- -- 'username', 'adminSetUserMFAPreference_username' - The user pool username or alias. -- -- 'userPoolId', 'adminSetUserMFAPreference_userPoolId' - The user pool ID. newAdminSetUserMFAPreference :: -- | 'username' Prelude.Text -> -- | 'userPoolId' Prelude.Text -> AdminSetUserMFAPreference newAdminSetUserMFAPreference pUsername_ pUserPoolId_ = AdminSetUserMFAPreference' { sMSMfaSettings = Prelude.Nothing, softwareTokenMfaSettings = Prelude.Nothing, username = Data._Sensitive Lens.# pUsername_, userPoolId = pUserPoolId_ } -- | The SMS text message MFA settings. adminSetUserMFAPreference_sMSMfaSettings :: Lens.Lens' AdminSetUserMFAPreference (Prelude.Maybe SMSMfaSettingsType) adminSetUserMFAPreference_sMSMfaSettings = Lens.lens (\AdminSetUserMFAPreference' {sMSMfaSettings} -> sMSMfaSettings) (\s@AdminSetUserMFAPreference' {} a -> s {sMSMfaSettings = a} :: AdminSetUserMFAPreference) -- | The time-based one-time password software token MFA settings. adminSetUserMFAPreference_softwareTokenMfaSettings :: Lens.Lens' AdminSetUserMFAPreference (Prelude.Maybe SoftwareTokenMfaSettingsType) adminSetUserMFAPreference_softwareTokenMfaSettings = Lens.lens (\AdminSetUserMFAPreference' {softwareTokenMfaSettings} -> softwareTokenMfaSettings) (\s@AdminSetUserMFAPreference' {} a -> s {softwareTokenMfaSettings = a} :: AdminSetUserMFAPreference) -- | The user pool username or alias. adminSetUserMFAPreference_username :: Lens.Lens' AdminSetUserMFAPreference Prelude.Text adminSetUserMFAPreference_username = Lens.lens (\AdminSetUserMFAPreference' {username} -> username) (\s@AdminSetUserMFAPreference' {} a -> s {username = a} :: AdminSetUserMFAPreference) Prelude.. Data._Sensitive -- | The user pool ID. adminSetUserMFAPreference_userPoolId :: Lens.Lens' AdminSetUserMFAPreference Prelude.Text adminSetUserMFAPreference_userPoolId = Lens.lens (\AdminSetUserMFAPreference' {userPoolId} -> userPoolId) (\s@AdminSetUserMFAPreference' {} a -> s {userPoolId = a} :: AdminSetUserMFAPreference) instance Core.AWSRequest AdminSetUserMFAPreference where type AWSResponse AdminSetUserMFAPreference = AdminSetUserMFAPreferenceResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveEmpty ( \s h x -> AdminSetUserMFAPreferenceResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable AdminSetUserMFAPreference where hashWithSalt _salt AdminSetUserMFAPreference' {..} = _salt `Prelude.hashWithSalt` sMSMfaSettings `Prelude.hashWithSalt` softwareTokenMfaSettings `Prelude.hashWithSalt` username `Prelude.hashWithSalt` userPoolId instance Prelude.NFData AdminSetUserMFAPreference where rnf AdminSetUserMFAPreference' {..} = Prelude.rnf sMSMfaSettings `Prelude.seq` Prelude.rnf softwareTokenMfaSettings `Prelude.seq` Prelude.rnf username `Prelude.seq` Prelude.rnf userPoolId instance Data.ToHeaders AdminSetUserMFAPreference where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AWSCognitoIdentityProviderService.AdminSetUserMFAPreference" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON AdminSetUserMFAPreference where toJSON AdminSetUserMFAPreference' {..} = Data.object ( Prelude.catMaybes [ ("SMSMfaSettings" Data..=) Prelude.<$> sMSMfaSettings, ("SoftwareTokenMfaSettings" Data..=) Prelude.<$> softwareTokenMfaSettings, Prelude.Just ("Username" Data..= username), Prelude.Just ("UserPoolId" Data..= userPoolId) ] ) instance Data.ToPath AdminSetUserMFAPreference where toPath = Prelude.const "/" instance Data.ToQuery AdminSetUserMFAPreference where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newAdminSetUserMFAPreferenceResponse' smart constructor. data AdminSetUserMFAPreferenceResponse = AdminSetUserMFAPreferenceResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'AdminSetUserMFAPreferenceResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'httpStatus', 'adminSetUserMFAPreferenceResponse_httpStatus' - The response's http status code. newAdminSetUserMFAPreferenceResponse :: -- | 'httpStatus' Prelude.Int -> AdminSetUserMFAPreferenceResponse newAdminSetUserMFAPreferenceResponse pHttpStatus_ = AdminSetUserMFAPreferenceResponse' { httpStatus = pHttpStatus_ } -- | The response's http status code. adminSetUserMFAPreferenceResponse_httpStatus :: Lens.Lens' AdminSetUserMFAPreferenceResponse Prelude.Int adminSetUserMFAPreferenceResponse_httpStatus = Lens.lens (\AdminSetUserMFAPreferenceResponse' {httpStatus} -> httpStatus) (\s@AdminSetUserMFAPreferenceResponse' {} a -> s {httpStatus = a} :: AdminSetUserMFAPreferenceResponse) instance Prelude.NFData AdminSetUserMFAPreferenceResponse where rnf AdminSetUserMFAPreferenceResponse' {..} = Prelude.rnf httpStatus