{-# 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.DeleteSubnetCidrReservation -- 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 subnet CIDR reservation. module Amazonka.EC2.DeleteSubnetCidrReservation ( -- * Creating a Request DeleteSubnetCidrReservation (..), newDeleteSubnetCidrReservation, -- * Request Lenses deleteSubnetCidrReservation_dryRun, deleteSubnetCidrReservation_subnetCidrReservationId, -- * Destructuring the Response DeleteSubnetCidrReservationResponse (..), newDeleteSubnetCidrReservationResponse, -- * Response Lenses deleteSubnetCidrReservationResponse_deletedSubnetCidrReservation, deleteSubnetCidrReservationResponse_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:/ 'newDeleteSubnetCidrReservation' smart constructor. data DeleteSubnetCidrReservation = DeleteSubnetCidrReservation' { -- | 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 subnet CIDR reservation. subnetCidrReservationId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteSubnetCidrReservation' 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', 'deleteSubnetCidrReservation_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@. -- -- 'subnetCidrReservationId', 'deleteSubnetCidrReservation_subnetCidrReservationId' - The ID of the subnet CIDR reservation. newDeleteSubnetCidrReservation :: -- | 'subnetCidrReservationId' Prelude.Text -> DeleteSubnetCidrReservation newDeleteSubnetCidrReservation pSubnetCidrReservationId_ = DeleteSubnetCidrReservation' { dryRun = Prelude.Nothing, subnetCidrReservationId = pSubnetCidrReservationId_ } -- | 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@. deleteSubnetCidrReservation_dryRun :: Lens.Lens' DeleteSubnetCidrReservation (Prelude.Maybe Prelude.Bool) deleteSubnetCidrReservation_dryRun = Lens.lens (\DeleteSubnetCidrReservation' {dryRun} -> dryRun) (\s@DeleteSubnetCidrReservation' {} a -> s {dryRun = a} :: DeleteSubnetCidrReservation) -- | The ID of the subnet CIDR reservation. deleteSubnetCidrReservation_subnetCidrReservationId :: Lens.Lens' DeleteSubnetCidrReservation Prelude.Text deleteSubnetCidrReservation_subnetCidrReservationId = Lens.lens (\DeleteSubnetCidrReservation' {subnetCidrReservationId} -> subnetCidrReservationId) (\s@DeleteSubnetCidrReservation' {} a -> s {subnetCidrReservationId = a} :: DeleteSubnetCidrReservation) instance Core.AWSRequest DeleteSubnetCidrReservation where type AWSResponse DeleteSubnetCidrReservation = DeleteSubnetCidrReservationResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXML ( \s h x -> DeleteSubnetCidrReservationResponse' Prelude.<$> (x Data..@? "deletedSubnetCidrReservation") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeleteSubnetCidrReservation where hashWithSalt _salt DeleteSubnetCidrReservation' {..} = _salt `Prelude.hashWithSalt` dryRun `Prelude.hashWithSalt` subnetCidrReservationId instance Prelude.NFData DeleteSubnetCidrReservation where rnf DeleteSubnetCidrReservation' {..} = Prelude.rnf dryRun `Prelude.seq` Prelude.rnf subnetCidrReservationId instance Data.ToHeaders DeleteSubnetCidrReservation where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath DeleteSubnetCidrReservation where toPath = Prelude.const "/" instance Data.ToQuery DeleteSubnetCidrReservation where toQuery DeleteSubnetCidrReservation' {..} = Prelude.mconcat [ "Action" Data.=: ( "DeleteSubnetCidrReservation" :: Prelude.ByteString ), "Version" Data.=: ("2016-11-15" :: Prelude.ByteString), "DryRun" Data.=: dryRun, "SubnetCidrReservationId" Data.=: subnetCidrReservationId ] -- | /See:/ 'newDeleteSubnetCidrReservationResponse' smart constructor. data DeleteSubnetCidrReservationResponse = DeleteSubnetCidrReservationResponse' { -- | Information about the deleted subnet CIDR reservation. deletedSubnetCidrReservation :: Prelude.Maybe SubnetCidrReservation, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteSubnetCidrReservationResponse' 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: -- -- 'deletedSubnetCidrReservation', 'deleteSubnetCidrReservationResponse_deletedSubnetCidrReservation' - Information about the deleted subnet CIDR reservation. -- -- 'httpStatus', 'deleteSubnetCidrReservationResponse_httpStatus' - The response's http status code. newDeleteSubnetCidrReservationResponse :: -- | 'httpStatus' Prelude.Int -> DeleteSubnetCidrReservationResponse newDeleteSubnetCidrReservationResponse pHttpStatus_ = DeleteSubnetCidrReservationResponse' { deletedSubnetCidrReservation = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Information about the deleted subnet CIDR reservation. deleteSubnetCidrReservationResponse_deletedSubnetCidrReservation :: Lens.Lens' DeleteSubnetCidrReservationResponse (Prelude.Maybe SubnetCidrReservation) deleteSubnetCidrReservationResponse_deletedSubnetCidrReservation = Lens.lens (\DeleteSubnetCidrReservationResponse' {deletedSubnetCidrReservation} -> deletedSubnetCidrReservation) (\s@DeleteSubnetCidrReservationResponse' {} a -> s {deletedSubnetCidrReservation = a} :: DeleteSubnetCidrReservationResponse) -- | The response's http status code. deleteSubnetCidrReservationResponse_httpStatus :: Lens.Lens' DeleteSubnetCidrReservationResponse Prelude.Int deleteSubnetCidrReservationResponse_httpStatus = Lens.lens (\DeleteSubnetCidrReservationResponse' {httpStatus} -> httpStatus) (\s@DeleteSubnetCidrReservationResponse' {} a -> s {httpStatus = a} :: DeleteSubnetCidrReservationResponse) instance Prelude.NFData DeleteSubnetCidrReservationResponse where rnf DeleteSubnetCidrReservationResponse' {..} = Prelude.rnf deletedSubnetCidrReservation `Prelude.seq` Prelude.rnf httpStatus