{-# 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.DeleteTransitGatewayPeeringAttachment -- 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 a transit gateway peering attachment. module Amazonka.EC2.DeleteTransitGatewayPeeringAttachment ( -- * Creating a Request DeleteTransitGatewayPeeringAttachment (..), newDeleteTransitGatewayPeeringAttachment, -- * Request Lenses deleteTransitGatewayPeeringAttachment_dryRun, deleteTransitGatewayPeeringAttachment_transitGatewayAttachmentId, -- * Destructuring the Response DeleteTransitGatewayPeeringAttachmentResponse (..), newDeleteTransitGatewayPeeringAttachmentResponse, -- * Response Lenses deleteTransitGatewayPeeringAttachmentResponse_transitGatewayPeeringAttachment, deleteTransitGatewayPeeringAttachmentResponse_httpStatus, ) 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:/ 'newDeleteTransitGatewayPeeringAttachment' smart constructor. data DeleteTransitGatewayPeeringAttachment = DeleteTransitGatewayPeeringAttachment' { -- | 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 ID of the transit gateway peering attachment. transitGatewayAttachmentId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteTransitGatewayPeeringAttachment' 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', 'deleteTransitGatewayPeeringAttachment_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@. -- -- 'transitGatewayAttachmentId', 'deleteTransitGatewayPeeringAttachment_transitGatewayAttachmentId' - The ID of the transit gateway peering attachment. newDeleteTransitGatewayPeeringAttachment :: -- | 'transitGatewayAttachmentId' Prelude.Text -> DeleteTransitGatewayPeeringAttachment newDeleteTransitGatewayPeeringAttachment pTransitGatewayAttachmentId_ = DeleteTransitGatewayPeeringAttachment' { dryRun = Prelude.Nothing, transitGatewayAttachmentId = pTransitGatewayAttachmentId_ } -- | 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@. deleteTransitGatewayPeeringAttachment_dryRun :: Lens.Lens' DeleteTransitGatewayPeeringAttachment (Prelude.Maybe Prelude.Bool) deleteTransitGatewayPeeringAttachment_dryRun = Lens.lens (\DeleteTransitGatewayPeeringAttachment' {dryRun} -> dryRun) (\s@DeleteTransitGatewayPeeringAttachment' {} a -> s {dryRun = a} :: DeleteTransitGatewayPeeringAttachment) -- | The ID of the transit gateway peering attachment. deleteTransitGatewayPeeringAttachment_transitGatewayAttachmentId :: Lens.Lens' DeleteTransitGatewayPeeringAttachment Prelude.Text deleteTransitGatewayPeeringAttachment_transitGatewayAttachmentId = Lens.lens (\DeleteTransitGatewayPeeringAttachment' {transitGatewayAttachmentId} -> transitGatewayAttachmentId) (\s@DeleteTransitGatewayPeeringAttachment' {} a -> s {transitGatewayAttachmentId = a} :: DeleteTransitGatewayPeeringAttachment) instance Core.AWSRequest DeleteTransitGatewayPeeringAttachment where type AWSResponse DeleteTransitGatewayPeeringAttachment = DeleteTransitGatewayPeeringAttachmentResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXML ( \s h x -> DeleteTransitGatewayPeeringAttachmentResponse' Prelude.<$> (x Data..@? "transitGatewayPeeringAttachment") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeleteTransitGatewayPeeringAttachment where hashWithSalt _salt DeleteTransitGatewayPeeringAttachment' {..} = _salt `Prelude.hashWithSalt` dryRun `Prelude.hashWithSalt` transitGatewayAttachmentId instance Prelude.NFData DeleteTransitGatewayPeeringAttachment where rnf DeleteTransitGatewayPeeringAttachment' {..} = Prelude.rnf dryRun `Prelude.seq` Prelude.rnf transitGatewayAttachmentId instance Data.ToHeaders DeleteTransitGatewayPeeringAttachment where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath DeleteTransitGatewayPeeringAttachment where toPath = Prelude.const "/" instance Data.ToQuery DeleteTransitGatewayPeeringAttachment where toQuery DeleteTransitGatewayPeeringAttachment' {..} = Prelude.mconcat [ "Action" Data.=: ( "DeleteTransitGatewayPeeringAttachment" :: Prelude.ByteString ), "Version" Data.=: ("2016-11-15" :: Prelude.ByteString), "DryRun" Data.=: dryRun, "TransitGatewayAttachmentId" Data.=: transitGatewayAttachmentId ] -- | /See:/ 'newDeleteTransitGatewayPeeringAttachmentResponse' smart constructor. data DeleteTransitGatewayPeeringAttachmentResponse = DeleteTransitGatewayPeeringAttachmentResponse' { -- | The transit gateway peering attachment. transitGatewayPeeringAttachment :: Prelude.Maybe TransitGatewayPeeringAttachment, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteTransitGatewayPeeringAttachmentResponse' 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: -- -- 'transitGatewayPeeringAttachment', 'deleteTransitGatewayPeeringAttachmentResponse_transitGatewayPeeringAttachment' - The transit gateway peering attachment. -- -- 'httpStatus', 'deleteTransitGatewayPeeringAttachmentResponse_httpStatus' - The response's http status code. newDeleteTransitGatewayPeeringAttachmentResponse :: -- | 'httpStatus' Prelude.Int -> DeleteTransitGatewayPeeringAttachmentResponse newDeleteTransitGatewayPeeringAttachmentResponse pHttpStatus_ = DeleteTransitGatewayPeeringAttachmentResponse' { transitGatewayPeeringAttachment = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The transit gateway peering attachment. deleteTransitGatewayPeeringAttachmentResponse_transitGatewayPeeringAttachment :: Lens.Lens' DeleteTransitGatewayPeeringAttachmentResponse (Prelude.Maybe TransitGatewayPeeringAttachment) deleteTransitGatewayPeeringAttachmentResponse_transitGatewayPeeringAttachment = Lens.lens (\DeleteTransitGatewayPeeringAttachmentResponse' {transitGatewayPeeringAttachment} -> transitGatewayPeeringAttachment) (\s@DeleteTransitGatewayPeeringAttachmentResponse' {} a -> s {transitGatewayPeeringAttachment = a} :: DeleteTransitGatewayPeeringAttachmentResponse) -- | The response's http status code. deleteTransitGatewayPeeringAttachmentResponse_httpStatus :: Lens.Lens' DeleteTransitGatewayPeeringAttachmentResponse Prelude.Int deleteTransitGatewayPeeringAttachmentResponse_httpStatus = Lens.lens (\DeleteTransitGatewayPeeringAttachmentResponse' {httpStatus} -> httpStatus) (\s@DeleteTransitGatewayPeeringAttachmentResponse' {} a -> s {httpStatus = a} :: DeleteTransitGatewayPeeringAttachmentResponse) instance Prelude.NFData DeleteTransitGatewayPeeringAttachmentResponse where rnf DeleteTransitGatewayPeeringAttachmentResponse' {..} = Prelude.rnf transitGatewayPeeringAttachment `Prelude.seq` Prelude.rnf httpStatus