{-# 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.DeprovisionByoipCidr -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Releases the specified address range that you provisioned for use with -- your Amazon Web Services resources through bring your own IP addresses -- (BYOIP) and deletes the corresponding address pool. -- -- Before you can release an address range, you must stop advertising it -- using WithdrawByoipCidr and you must not have any IP addresses allocated -- from its address range. module Amazonka.EC2.DeprovisionByoipCidr ( -- * Creating a Request DeprovisionByoipCidr (..), newDeprovisionByoipCidr, -- * Request Lenses deprovisionByoipCidr_dryRun, deprovisionByoipCidr_cidr, -- * Destructuring the Response DeprovisionByoipCidrResponse (..), newDeprovisionByoipCidrResponse, -- * Response Lenses deprovisionByoipCidrResponse_byoipCidr, deprovisionByoipCidrResponse_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:/ 'newDeprovisionByoipCidr' smart constructor. data DeprovisionByoipCidr = DeprovisionByoipCidr' { -- | 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 address range, in CIDR notation. The prefix must be the same prefix -- that you specified when you provisioned the address range. cidr :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeprovisionByoipCidr' 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', 'deprovisionByoipCidr_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@. -- -- 'cidr', 'deprovisionByoipCidr_cidr' - The address range, in CIDR notation. The prefix must be the same prefix -- that you specified when you provisioned the address range. newDeprovisionByoipCidr :: -- | 'cidr' Prelude.Text -> DeprovisionByoipCidr newDeprovisionByoipCidr pCidr_ = DeprovisionByoipCidr' { dryRun = Prelude.Nothing, cidr = pCidr_ } -- | 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@. deprovisionByoipCidr_dryRun :: Lens.Lens' DeprovisionByoipCidr (Prelude.Maybe Prelude.Bool) deprovisionByoipCidr_dryRun = Lens.lens (\DeprovisionByoipCidr' {dryRun} -> dryRun) (\s@DeprovisionByoipCidr' {} a -> s {dryRun = a} :: DeprovisionByoipCidr) -- | The address range, in CIDR notation. The prefix must be the same prefix -- that you specified when you provisioned the address range. deprovisionByoipCidr_cidr :: Lens.Lens' DeprovisionByoipCidr Prelude.Text deprovisionByoipCidr_cidr = Lens.lens (\DeprovisionByoipCidr' {cidr} -> cidr) (\s@DeprovisionByoipCidr' {} a -> s {cidr = a} :: DeprovisionByoipCidr) instance Core.AWSRequest DeprovisionByoipCidr where type AWSResponse DeprovisionByoipCidr = DeprovisionByoipCidrResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXML ( \s h x -> DeprovisionByoipCidrResponse' Prelude.<$> (x Data..@? "byoipCidr") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeprovisionByoipCidr where hashWithSalt _salt DeprovisionByoipCidr' {..} = _salt `Prelude.hashWithSalt` dryRun `Prelude.hashWithSalt` cidr instance Prelude.NFData DeprovisionByoipCidr where rnf DeprovisionByoipCidr' {..} = Prelude.rnf dryRun `Prelude.seq` Prelude.rnf cidr instance Data.ToHeaders DeprovisionByoipCidr where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath DeprovisionByoipCidr where toPath = Prelude.const "/" instance Data.ToQuery DeprovisionByoipCidr where toQuery DeprovisionByoipCidr' {..} = Prelude.mconcat [ "Action" Data.=: ("DeprovisionByoipCidr" :: Prelude.ByteString), "Version" Data.=: ("2016-11-15" :: Prelude.ByteString), "DryRun" Data.=: dryRun, "Cidr" Data.=: cidr ] -- | /See:/ 'newDeprovisionByoipCidrResponse' smart constructor. data DeprovisionByoipCidrResponse = DeprovisionByoipCidrResponse' { -- | Information about the address range. byoipCidr :: Prelude.Maybe ByoipCidr, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeprovisionByoipCidrResponse' 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: -- -- 'byoipCidr', 'deprovisionByoipCidrResponse_byoipCidr' - Information about the address range. -- -- 'httpStatus', 'deprovisionByoipCidrResponse_httpStatus' - The response's http status code. newDeprovisionByoipCidrResponse :: -- | 'httpStatus' Prelude.Int -> DeprovisionByoipCidrResponse newDeprovisionByoipCidrResponse pHttpStatus_ = DeprovisionByoipCidrResponse' { byoipCidr = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Information about the address range. deprovisionByoipCidrResponse_byoipCidr :: Lens.Lens' DeprovisionByoipCidrResponse (Prelude.Maybe ByoipCidr) deprovisionByoipCidrResponse_byoipCidr = Lens.lens (\DeprovisionByoipCidrResponse' {byoipCidr} -> byoipCidr) (\s@DeprovisionByoipCidrResponse' {} a -> s {byoipCidr = a} :: DeprovisionByoipCidrResponse) -- | The response's http status code. deprovisionByoipCidrResponse_httpStatus :: Lens.Lens' DeprovisionByoipCidrResponse Prelude.Int deprovisionByoipCidrResponse_httpStatus = Lens.lens (\DeprovisionByoipCidrResponse' {httpStatus} -> httpStatus) (\s@DeprovisionByoipCidrResponse' {} a -> s {httpStatus = a} :: DeprovisionByoipCidrResponse) instance Prelude.NFData DeprovisionByoipCidrResponse where rnf DeprovisionByoipCidrResponse' {..} = Prelude.rnf byoipCidr `Prelude.seq` Prelude.rnf httpStatus