{-# 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.DeleteAccessKey -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Deletes the access key pair associated with the specified IAM user. -- -- If you do not specify a user name, IAM determines the user name -- implicitly based on the Amazon Web Services access key ID signing the -- request. This operation works for access keys under the Amazon Web -- Services account. Consequently, you can use this operation to manage -- Amazon Web Services account root user credentials even if the Amazon Web -- Services account has no associated users. module Amazonka.IAM.DeleteAccessKey ( -- * Creating a Request DeleteAccessKey (..), newDeleteAccessKey, -- * Request Lenses deleteAccessKey_userName, deleteAccessKey_accessKeyId, -- * Destructuring the Response DeleteAccessKeyResponse (..), newDeleteAccessKeyResponse, ) 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:/ 'newDeleteAccessKey' smart constructor. data DeleteAccessKey = DeleteAccessKey' { -- | The name of the user whose access key pair you want to delete. -- -- 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 access key ID for the access key ID and secret access key you want -- to delete. -- -- This parameter allows (through its -- ) a string of characters -- that can consist of any upper or lowercased letter or digit. accessKeyId :: Core.AccessKey } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteAccessKey' 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', 'deleteAccessKey_userName' - The name of the user whose access key pair you want to delete. -- -- 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: _+=,.\@- -- -- 'accessKeyId', 'deleteAccessKey_accessKeyId' - The access key ID for the access key ID and secret access key you want -- to delete. -- -- This parameter allows (through its -- ) a string of characters -- that can consist of any upper or lowercased letter or digit. newDeleteAccessKey :: -- | 'accessKeyId' Core.AccessKey -> DeleteAccessKey newDeleteAccessKey pAccessKeyId_ = DeleteAccessKey' { userName = Prelude.Nothing, accessKeyId = pAccessKeyId_ } -- | The name of the user whose access key pair you want to delete. -- -- 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: _+=,.\@- deleteAccessKey_userName :: Lens.Lens' DeleteAccessKey (Prelude.Maybe Prelude.Text) deleteAccessKey_userName = Lens.lens (\DeleteAccessKey' {userName} -> userName) (\s@DeleteAccessKey' {} a -> s {userName = a} :: DeleteAccessKey) -- | The access key ID for the access key ID and secret access key you want -- to delete. -- -- This parameter allows (through its -- ) a string of characters -- that can consist of any upper or lowercased letter or digit. deleteAccessKey_accessKeyId :: Lens.Lens' DeleteAccessKey Core.AccessKey deleteAccessKey_accessKeyId = Lens.lens (\DeleteAccessKey' {accessKeyId} -> accessKeyId) (\s@DeleteAccessKey' {} a -> s {accessKeyId = a} :: DeleteAccessKey) instance Core.AWSRequest DeleteAccessKey where type AWSResponse DeleteAccessKey = DeleteAccessKeyResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveNull DeleteAccessKeyResponse' instance Prelude.Hashable DeleteAccessKey where hashWithSalt _salt DeleteAccessKey' {..} = _salt `Prelude.hashWithSalt` userName `Prelude.hashWithSalt` accessKeyId instance Prelude.NFData DeleteAccessKey where rnf DeleteAccessKey' {..} = Prelude.rnf userName `Prelude.seq` Prelude.rnf accessKeyId instance Data.ToHeaders DeleteAccessKey where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath DeleteAccessKey where toPath = Prelude.const "/" instance Data.ToQuery DeleteAccessKey where toQuery DeleteAccessKey' {..} = Prelude.mconcat [ "Action" Data.=: ("DeleteAccessKey" :: Prelude.ByteString), "Version" Data.=: ("2010-05-08" :: Prelude.ByteString), "UserName" Data.=: userName, "AccessKeyId" Data.=: accessKeyId ] -- | /See:/ 'newDeleteAccessKeyResponse' smart constructor. data DeleteAccessKeyResponse = DeleteAccessKeyResponse' { } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteAccessKeyResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. newDeleteAccessKeyResponse :: DeleteAccessKeyResponse newDeleteAccessKeyResponse = DeleteAccessKeyResponse' instance Prelude.NFData DeleteAccessKeyResponse where rnf _ = ()