{-# 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.EC2.DeleteKeyPair -- 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 specified key pair, by removing the public key from Amazon -- EC2. module Amazonka.EC2.DeleteKeyPair ( -- * Creating a Request DeleteKeyPair (..), newDeleteKeyPair, -- * Request Lenses deleteKeyPair_dryRun, deleteKeyPair_keyName, deleteKeyPair_keyPairId, -- * Destructuring the Response DeleteKeyPairResponse (..), newDeleteKeyPairResponse, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.EC2.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newDeleteKeyPair' smart constructor. data DeleteKeyPair = DeleteKeyPair' { -- | Checks whether you have the required permissions for the action, without -- actually making the request, and provides an error response. If you have -- the required permissions, the error response is @DryRunOperation@. -- Otherwise, it is @UnauthorizedOperation@. dryRun :: Prelude.Maybe Prelude.Bool, -- | The name of the key pair. keyName :: Prelude.Maybe Prelude.Text, -- | The ID of the key pair. keyPairId :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteKeyPair' 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: -- -- 'dryRun', 'deleteKeyPair_dryRun' - Checks whether you have the required permissions for the action, without -- actually making the request, and provides an error response. If you have -- the required permissions, the error response is @DryRunOperation@. -- Otherwise, it is @UnauthorizedOperation@. -- -- 'keyName', 'deleteKeyPair_keyName' - The name of the key pair. -- -- 'keyPairId', 'deleteKeyPair_keyPairId' - The ID of the key pair. newDeleteKeyPair :: DeleteKeyPair newDeleteKeyPair = DeleteKeyPair' { dryRun = Prelude.Nothing, keyName = Prelude.Nothing, keyPairId = Prelude.Nothing } -- | Checks whether you have the required permissions for the action, without -- actually making the request, and provides an error response. If you have -- the required permissions, the error response is @DryRunOperation@. -- Otherwise, it is @UnauthorizedOperation@. deleteKeyPair_dryRun :: Lens.Lens' DeleteKeyPair (Prelude.Maybe Prelude.Bool) deleteKeyPair_dryRun = Lens.lens (\DeleteKeyPair' {dryRun} -> dryRun) (\s@DeleteKeyPair' {} a -> s {dryRun = a} :: DeleteKeyPair) -- | The name of the key pair. deleteKeyPair_keyName :: Lens.Lens' DeleteKeyPair (Prelude.Maybe Prelude.Text) deleteKeyPair_keyName = Lens.lens (\DeleteKeyPair' {keyName} -> keyName) (\s@DeleteKeyPair' {} a -> s {keyName = a} :: DeleteKeyPair) -- | The ID of the key pair. deleteKeyPair_keyPairId :: Lens.Lens' DeleteKeyPair (Prelude.Maybe Prelude.Text) deleteKeyPair_keyPairId = Lens.lens (\DeleteKeyPair' {keyPairId} -> keyPairId) (\s@DeleteKeyPair' {} a -> s {keyPairId = a} :: DeleteKeyPair) instance Core.AWSRequest DeleteKeyPair where type AWSResponse DeleteKeyPair = DeleteKeyPairResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveNull DeleteKeyPairResponse' instance Prelude.Hashable DeleteKeyPair where hashWithSalt _salt DeleteKeyPair' {..} = _salt `Prelude.hashWithSalt` dryRun `Prelude.hashWithSalt` keyName `Prelude.hashWithSalt` keyPairId instance Prelude.NFData DeleteKeyPair where rnf DeleteKeyPair' {..} = Prelude.rnf dryRun `Prelude.seq` Prelude.rnf keyName `Prelude.seq` Prelude.rnf keyPairId instance Data.ToHeaders DeleteKeyPair where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath DeleteKeyPair where toPath = Prelude.const "/" instance Data.ToQuery DeleteKeyPair where toQuery DeleteKeyPair' {..} = Prelude.mconcat [ "Action" Data.=: ("DeleteKeyPair" :: Prelude.ByteString), "Version" Data.=: ("2016-11-15" :: Prelude.ByteString), "DryRun" Data.=: dryRun, "KeyName" Data.=: keyName, "KeyPairId" Data.=: keyPairId ] -- | /See:/ 'newDeleteKeyPairResponse' smart constructor. data DeleteKeyPairResponse = DeleteKeyPairResponse' { } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteKeyPairResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. newDeleteKeyPairResponse :: DeleteKeyPairResponse newDeleteKeyPairResponse = DeleteKeyPairResponse' instance Prelude.NFData DeleteKeyPairResponse where rnf _ = ()