{-# 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.IAM.UpdateServiceSpecificCredential -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Sets the status of a service-specific credential to @Active@ or -- @Inactive@. Service-specific credentials that are inactive cannot be -- used for authentication to the service. This operation can be used to -- disable a user\'s service-specific credential as part of a credential -- rotation work flow. module Amazonka.IAM.UpdateServiceSpecificCredential ( -- * Creating a Request UpdateServiceSpecificCredential (..), newUpdateServiceSpecificCredential, -- * Request Lenses updateServiceSpecificCredential_userName, updateServiceSpecificCredential_serviceSpecificCredentialId, updateServiceSpecificCredential_status, -- * Destructuring the Response UpdateServiceSpecificCredentialResponse (..), newUpdateServiceSpecificCredentialResponse, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.IAM.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newUpdateServiceSpecificCredential' smart constructor. data UpdateServiceSpecificCredential = UpdateServiceSpecificCredential' { -- | The name of the IAM user associated with the service-specific -- credential. If you do not specify this value, then the operation assumes -- the user whose credentials are used to call the operation. -- -- This parameter allows (through its -- ) a string of characters -- consisting of upper and lowercase alphanumeric characters with no -- spaces. You can also include any of the following characters: _+=,.\@- userName :: Prelude.Maybe Prelude.Text, -- | The unique identifier of the service-specific credential. -- -- This parameter allows (through its -- ) a string of characters -- that can consist of any upper or lowercased letter or digit. serviceSpecificCredentialId :: Prelude.Text, -- | The status to be assigned to the service-specific credential. status :: StatusType } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateServiceSpecificCredential' 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: -- -- 'userName', 'updateServiceSpecificCredential_userName' - The name of the IAM user associated with the service-specific -- credential. If you do not specify this value, then the operation assumes -- the user whose credentials are used to call the operation. -- -- This parameter allows (through its -- ) a string of characters -- consisting of upper and lowercase alphanumeric characters with no -- spaces. You can also include any of the following characters: _+=,.\@- -- -- 'serviceSpecificCredentialId', 'updateServiceSpecificCredential_serviceSpecificCredentialId' - The unique identifier of the service-specific credential. -- -- This parameter allows (through its -- ) a string of characters -- that can consist of any upper or lowercased letter or digit. -- -- 'status', 'updateServiceSpecificCredential_status' - The status to be assigned to the service-specific credential. newUpdateServiceSpecificCredential :: -- | 'serviceSpecificCredentialId' Prelude.Text -> -- | 'status' StatusType -> UpdateServiceSpecificCredential newUpdateServiceSpecificCredential pServiceSpecificCredentialId_ pStatus_ = UpdateServiceSpecificCredential' { userName = Prelude.Nothing, serviceSpecificCredentialId = pServiceSpecificCredentialId_, status = pStatus_ } -- | The name of the IAM user associated with the service-specific -- credential. If you do not specify this value, then the operation assumes -- the user whose credentials are used to call the operation. -- -- This parameter allows (through its -- ) a string of characters -- consisting of upper and lowercase alphanumeric characters with no -- spaces. You can also include any of the following characters: _+=,.\@- updateServiceSpecificCredential_userName :: Lens.Lens' UpdateServiceSpecificCredential (Prelude.Maybe Prelude.Text) updateServiceSpecificCredential_userName = Lens.lens (\UpdateServiceSpecificCredential' {userName} -> userName) (\s@UpdateServiceSpecificCredential' {} a -> s {userName = a} :: UpdateServiceSpecificCredential) -- | The unique identifier of the service-specific credential. -- -- This parameter allows (through its -- ) a string of characters -- that can consist of any upper or lowercased letter or digit. updateServiceSpecificCredential_serviceSpecificCredentialId :: Lens.Lens' UpdateServiceSpecificCredential Prelude.Text updateServiceSpecificCredential_serviceSpecificCredentialId = Lens.lens (\UpdateServiceSpecificCredential' {serviceSpecificCredentialId} -> serviceSpecificCredentialId) (\s@UpdateServiceSpecificCredential' {} a -> s {serviceSpecificCredentialId = a} :: UpdateServiceSpecificCredential) -- | The status to be assigned to the service-specific credential. updateServiceSpecificCredential_status :: Lens.Lens' UpdateServiceSpecificCredential StatusType updateServiceSpecificCredential_status = Lens.lens (\UpdateServiceSpecificCredential' {status} -> status) (\s@UpdateServiceSpecificCredential' {} a -> s {status = a} :: UpdateServiceSpecificCredential) instance Core.AWSRequest UpdateServiceSpecificCredential where type AWSResponse UpdateServiceSpecificCredential = UpdateServiceSpecificCredentialResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveNull UpdateServiceSpecificCredentialResponse' instance Prelude.Hashable UpdateServiceSpecificCredential where hashWithSalt _salt UpdateServiceSpecificCredential' {..} = _salt `Prelude.hashWithSalt` userName `Prelude.hashWithSalt` serviceSpecificCredentialId `Prelude.hashWithSalt` status instance Prelude.NFData UpdateServiceSpecificCredential where rnf UpdateServiceSpecificCredential' {..} = Prelude.rnf userName `Prelude.seq` Prelude.rnf serviceSpecificCredentialId `Prelude.seq` Prelude.rnf status instance Data.ToHeaders UpdateServiceSpecificCredential where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath UpdateServiceSpecificCredential where toPath = Prelude.const "/" instance Data.ToQuery UpdateServiceSpecificCredential where toQuery UpdateServiceSpecificCredential' {..} = Prelude.mconcat [ "Action" Data.=: ( "UpdateServiceSpecificCredential" :: Prelude.ByteString ), "Version" Data.=: ("2010-05-08" :: Prelude.ByteString), "UserName" Data.=: userName, "ServiceSpecificCredentialId" Data.=: serviceSpecificCredentialId, "Status" Data.=: status ] -- | /See:/ 'newUpdateServiceSpecificCredentialResponse' smart constructor. data UpdateServiceSpecificCredentialResponse = UpdateServiceSpecificCredentialResponse' { } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateServiceSpecificCredentialResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. newUpdateServiceSpecificCredentialResponse :: UpdateServiceSpecificCredentialResponse newUpdateServiceSpecificCredentialResponse = UpdateServiceSpecificCredentialResponse' instance Prelude.NFData UpdateServiceSpecificCredentialResponse where rnf _ = ()