{-# 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.GlobalAccelerator.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 to 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 by -- using -- -- and you must not have any accelerators that are using static IP -- addresses allocated from its address range. -- -- For more information, see -- -- in the /Global Accelerator Developer Guide/. module Amazonka.GlobalAccelerator.DeprovisionByoipCidr ( -- * Creating a Request DeprovisionByoipCidr (..), newDeprovisionByoipCidr, -- * Request Lenses 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.GlobalAccelerator.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' { -- | 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: -- -- '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' {cidr = pCidr_} -- | 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.postJSON (overrides defaultService) response = Response.receiveJSON ( \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` cidr instance Prelude.NFData DeprovisionByoipCidr where rnf DeprovisionByoipCidr' {..} = Prelude.rnf cidr instance Data.ToHeaders DeprovisionByoipCidr where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "GlobalAccelerator_V20180706.DeprovisionByoipCidr" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DeprovisionByoipCidr where toJSON DeprovisionByoipCidr' {..} = Data.object ( Prelude.catMaybes [Prelude.Just ("Cidr" Data..= cidr)] ) instance Data.ToPath DeprovisionByoipCidr where toPath = Prelude.const "/" instance Data.ToQuery DeprovisionByoipCidr where toQuery = Prelude.const Prelude.mempty -- | /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