{-# 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.ElastiCache.PurchaseReservedCacheNodesOffering -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Allows you to purchase a reserved cache node offering. Reserved nodes -- are not eligible for cancellation and are non-refundable. For more -- information, see -- -- for Redis or -- -- for Memcached. module Amazonka.ElastiCache.PurchaseReservedCacheNodesOffering ( -- * Creating a Request PurchaseReservedCacheNodesOffering (..), newPurchaseReservedCacheNodesOffering, -- * Request Lenses purchaseReservedCacheNodesOffering_cacheNodeCount, purchaseReservedCacheNodesOffering_reservedCacheNodeId, purchaseReservedCacheNodesOffering_tags, purchaseReservedCacheNodesOffering_reservedCacheNodesOfferingId, -- * Destructuring the Response PurchaseReservedCacheNodesOfferingResponse (..), newPurchaseReservedCacheNodesOfferingResponse, -- * Response Lenses purchaseReservedCacheNodesOfferingResponse_reservedCacheNode, purchaseReservedCacheNodesOfferingResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.ElastiCache.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | Represents the input of a @PurchaseReservedCacheNodesOffering@ -- operation. -- -- /See:/ 'newPurchaseReservedCacheNodesOffering' smart constructor. data PurchaseReservedCacheNodesOffering = PurchaseReservedCacheNodesOffering' { -- | The number of cache node instances to reserve. -- -- Default: @1@ cacheNodeCount :: Prelude.Maybe Prelude.Int, -- | A customer-specified identifier to track this reservation. -- -- The Reserved Cache Node ID is an unique customer-specified identifier to -- track this reservation. If this parameter is not specified, ElastiCache -- automatically generates an identifier for the reservation. -- -- Example: myreservationID reservedCacheNodeId :: Prelude.Maybe Prelude.Text, -- | A list of tags to be added to this resource. A tag is a key-value pair. -- A tag key must be accompanied by a tag value, although null is accepted. tags :: Prelude.Maybe [Tag], -- | The ID of the reserved cache node offering to purchase. -- -- Example: @438012d3-4052-4cc7-b2e3-8d3372e0e706@ reservedCacheNodesOfferingId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'PurchaseReservedCacheNodesOffering' 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: -- -- 'cacheNodeCount', 'purchaseReservedCacheNodesOffering_cacheNodeCount' - The number of cache node instances to reserve. -- -- Default: @1@ -- -- 'reservedCacheNodeId', 'purchaseReservedCacheNodesOffering_reservedCacheNodeId' - A customer-specified identifier to track this reservation. -- -- The Reserved Cache Node ID is an unique customer-specified identifier to -- track this reservation. If this parameter is not specified, ElastiCache -- automatically generates an identifier for the reservation. -- -- Example: myreservationID -- -- 'tags', 'purchaseReservedCacheNodesOffering_tags' - A list of tags to be added to this resource. A tag is a key-value pair. -- A tag key must be accompanied by a tag value, although null is accepted. -- -- 'reservedCacheNodesOfferingId', 'purchaseReservedCacheNodesOffering_reservedCacheNodesOfferingId' - The ID of the reserved cache node offering to purchase. -- -- Example: @438012d3-4052-4cc7-b2e3-8d3372e0e706@ newPurchaseReservedCacheNodesOffering :: -- | 'reservedCacheNodesOfferingId' Prelude.Text -> PurchaseReservedCacheNodesOffering newPurchaseReservedCacheNodesOffering pReservedCacheNodesOfferingId_ = PurchaseReservedCacheNodesOffering' { cacheNodeCount = Prelude.Nothing, reservedCacheNodeId = Prelude.Nothing, tags = Prelude.Nothing, reservedCacheNodesOfferingId = pReservedCacheNodesOfferingId_ } -- | The number of cache node instances to reserve. -- -- Default: @1@ purchaseReservedCacheNodesOffering_cacheNodeCount :: Lens.Lens' PurchaseReservedCacheNodesOffering (Prelude.Maybe Prelude.Int) purchaseReservedCacheNodesOffering_cacheNodeCount = Lens.lens (\PurchaseReservedCacheNodesOffering' {cacheNodeCount} -> cacheNodeCount) (\s@PurchaseReservedCacheNodesOffering' {} a -> s {cacheNodeCount = a} :: PurchaseReservedCacheNodesOffering) -- | A customer-specified identifier to track this reservation. -- -- The Reserved Cache Node ID is an unique customer-specified identifier to -- track this reservation. If this parameter is not specified, ElastiCache -- automatically generates an identifier for the reservation. -- -- Example: myreservationID purchaseReservedCacheNodesOffering_reservedCacheNodeId :: Lens.Lens' PurchaseReservedCacheNodesOffering (Prelude.Maybe Prelude.Text) purchaseReservedCacheNodesOffering_reservedCacheNodeId = Lens.lens (\PurchaseReservedCacheNodesOffering' {reservedCacheNodeId} -> reservedCacheNodeId) (\s@PurchaseReservedCacheNodesOffering' {} a -> s {reservedCacheNodeId = a} :: PurchaseReservedCacheNodesOffering) -- | A list of tags to be added to this resource. A tag is a key-value pair. -- A tag key must be accompanied by a tag value, although null is accepted. purchaseReservedCacheNodesOffering_tags :: Lens.Lens' PurchaseReservedCacheNodesOffering (Prelude.Maybe [Tag]) purchaseReservedCacheNodesOffering_tags = Lens.lens (\PurchaseReservedCacheNodesOffering' {tags} -> tags) (\s@PurchaseReservedCacheNodesOffering' {} a -> s {tags = a} :: PurchaseReservedCacheNodesOffering) Prelude.. Lens.mapping Lens.coerced -- | The ID of the reserved cache node offering to purchase. -- -- Example: @438012d3-4052-4cc7-b2e3-8d3372e0e706@ purchaseReservedCacheNodesOffering_reservedCacheNodesOfferingId :: Lens.Lens' PurchaseReservedCacheNodesOffering Prelude.Text purchaseReservedCacheNodesOffering_reservedCacheNodesOfferingId = Lens.lens (\PurchaseReservedCacheNodesOffering' {reservedCacheNodesOfferingId} -> reservedCacheNodesOfferingId) (\s@PurchaseReservedCacheNodesOffering' {} a -> s {reservedCacheNodesOfferingId = a} :: PurchaseReservedCacheNodesOffering) instance Core.AWSRequest PurchaseReservedCacheNodesOffering where type AWSResponse PurchaseReservedCacheNodesOffering = PurchaseReservedCacheNodesOfferingResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXMLWrapper "PurchaseReservedCacheNodesOfferingResult" ( \s h x -> PurchaseReservedCacheNodesOfferingResponse' Prelude.<$> (x Data..@? "ReservedCacheNode") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable PurchaseReservedCacheNodesOffering where hashWithSalt _salt PurchaseReservedCacheNodesOffering' {..} = _salt `Prelude.hashWithSalt` cacheNodeCount `Prelude.hashWithSalt` reservedCacheNodeId `Prelude.hashWithSalt` tags `Prelude.hashWithSalt` reservedCacheNodesOfferingId instance Prelude.NFData PurchaseReservedCacheNodesOffering where rnf PurchaseReservedCacheNodesOffering' {..} = Prelude.rnf cacheNodeCount `Prelude.seq` Prelude.rnf reservedCacheNodeId `Prelude.seq` Prelude.rnf tags `Prelude.seq` Prelude.rnf reservedCacheNodesOfferingId instance Data.ToHeaders PurchaseReservedCacheNodesOffering where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath PurchaseReservedCacheNodesOffering where toPath = Prelude.const "/" instance Data.ToQuery PurchaseReservedCacheNodesOffering where toQuery PurchaseReservedCacheNodesOffering' {..} = Prelude.mconcat [ "Action" Data.=: ( "PurchaseReservedCacheNodesOffering" :: Prelude.ByteString ), "Version" Data.=: ("2015-02-02" :: Prelude.ByteString), "CacheNodeCount" Data.=: cacheNodeCount, "ReservedCacheNodeId" Data.=: reservedCacheNodeId, "Tags" Data.=: Data.toQuery (Data.toQueryList "Tag" Prelude.<$> tags), "ReservedCacheNodesOfferingId" Data.=: reservedCacheNodesOfferingId ] -- | /See:/ 'newPurchaseReservedCacheNodesOfferingResponse' smart constructor. data PurchaseReservedCacheNodesOfferingResponse = PurchaseReservedCacheNodesOfferingResponse' { reservedCacheNode :: Prelude.Maybe ReservedCacheNode, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'PurchaseReservedCacheNodesOfferingResponse' 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: -- -- 'reservedCacheNode', 'purchaseReservedCacheNodesOfferingResponse_reservedCacheNode' - Undocumented member. -- -- 'httpStatus', 'purchaseReservedCacheNodesOfferingResponse_httpStatus' - The response's http status code. newPurchaseReservedCacheNodesOfferingResponse :: -- | 'httpStatus' Prelude.Int -> PurchaseReservedCacheNodesOfferingResponse newPurchaseReservedCacheNodesOfferingResponse pHttpStatus_ = PurchaseReservedCacheNodesOfferingResponse' { reservedCacheNode = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Undocumented member. purchaseReservedCacheNodesOfferingResponse_reservedCacheNode :: Lens.Lens' PurchaseReservedCacheNodesOfferingResponse (Prelude.Maybe ReservedCacheNode) purchaseReservedCacheNodesOfferingResponse_reservedCacheNode = Lens.lens (\PurchaseReservedCacheNodesOfferingResponse' {reservedCacheNode} -> reservedCacheNode) (\s@PurchaseReservedCacheNodesOfferingResponse' {} a -> s {reservedCacheNode = a} :: PurchaseReservedCacheNodesOfferingResponse) -- | The response's http status code. purchaseReservedCacheNodesOfferingResponse_httpStatus :: Lens.Lens' PurchaseReservedCacheNodesOfferingResponse Prelude.Int purchaseReservedCacheNodesOfferingResponse_httpStatus = Lens.lens (\PurchaseReservedCacheNodesOfferingResponse' {httpStatus} -> httpStatus) (\s@PurchaseReservedCacheNodesOfferingResponse' {} a -> s {httpStatus = a} :: PurchaseReservedCacheNodesOfferingResponse) instance Prelude.NFData PurchaseReservedCacheNodesOfferingResponse where rnf PurchaseReservedCacheNodesOfferingResponse' {..} = Prelude.rnf reservedCacheNode `Prelude.seq` Prelude.rnf httpStatus