{-# 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.DescribeHostReservationOfferings -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Describes the Dedicated Host reservations that are available to -- purchase. -- -- The results describe all of the Dedicated Host reservation offerings, -- including offerings that might not match the instance family and Region -- of your Dedicated Hosts. When purchasing an offering, ensure that the -- instance family and Region of the offering matches that of the Dedicated -- Hosts with which it is to be associated. For more information about -- supported instance types, see -- -- in the /Amazon EC2 User Guide/. -- -- This operation returns paginated results. module Amazonka.EC2.DescribeHostReservationOfferings ( -- * Creating a Request DescribeHostReservationOfferings (..), newDescribeHostReservationOfferings, -- * Request Lenses describeHostReservationOfferings_filter, describeHostReservationOfferings_maxDuration, describeHostReservationOfferings_maxResults, describeHostReservationOfferings_minDuration, describeHostReservationOfferings_nextToken, describeHostReservationOfferings_offeringId, -- * Destructuring the Response DescribeHostReservationOfferingsResponse (..), newDescribeHostReservationOfferingsResponse, -- * Response Lenses describeHostReservationOfferingsResponse_nextToken, describeHostReservationOfferingsResponse_offeringSet, describeHostReservationOfferingsResponse_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:/ 'newDescribeHostReservationOfferings' smart constructor. data DescribeHostReservationOfferings = DescribeHostReservationOfferings' { -- | The filters. -- -- - @instance-family@ - The instance family of the offering (for -- example, @m4@). -- -- - @payment-option@ - The payment option (@NoUpfront@ | -- @PartialUpfront@ | @AllUpfront@). filter' :: Prelude.Maybe [Filter], -- | This is the maximum duration of the reservation to purchase, specified -- in seconds. Reservations are available in one-year and three-year terms. -- The number of seconds specified must be the number of seconds in a year -- (365x24x60x60) times one of the supported durations (1 or 3). For -- example, specify 94608000 for three years. maxDuration :: Prelude.Maybe Prelude.Int, -- | The maximum number of results to return for the request in a single -- page. The remaining results can be seen by sending another request with -- the returned @nextToken@ value. This value can be between 5 and 500. If -- @maxResults@ is given a larger value than 500, you receive an error. maxResults :: Prelude.Maybe Prelude.Natural, -- | This is the minimum duration of the reservation you\'d like to purchase, -- specified in seconds. Reservations are available in one-year and -- three-year terms. The number of seconds specified must be the number of -- seconds in a year (365x24x60x60) times one of the supported durations (1 -- or 3). For example, specify 31536000 for one year. minDuration :: Prelude.Maybe Prelude.Int, -- | The token to use to retrieve the next page of results. nextToken :: Prelude.Maybe Prelude.Text, -- | The ID of the reservation offering. offeringId :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeHostReservationOfferings' 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: -- -- 'filter'', 'describeHostReservationOfferings_filter' - The filters. -- -- - @instance-family@ - The instance family of the offering (for -- example, @m4@). -- -- - @payment-option@ - The payment option (@NoUpfront@ | -- @PartialUpfront@ | @AllUpfront@). -- -- 'maxDuration', 'describeHostReservationOfferings_maxDuration' - This is the maximum duration of the reservation to purchase, specified -- in seconds. Reservations are available in one-year and three-year terms. -- The number of seconds specified must be the number of seconds in a year -- (365x24x60x60) times one of the supported durations (1 or 3). For -- example, specify 94608000 for three years. -- -- 'maxResults', 'describeHostReservationOfferings_maxResults' - The maximum number of results to return for the request in a single -- page. The remaining results can be seen by sending another request with -- the returned @nextToken@ value. This value can be between 5 and 500. If -- @maxResults@ is given a larger value than 500, you receive an error. -- -- 'minDuration', 'describeHostReservationOfferings_minDuration' - This is the minimum duration of the reservation you\'d like to purchase, -- specified in seconds. Reservations are available in one-year and -- three-year terms. The number of seconds specified must be the number of -- seconds in a year (365x24x60x60) times one of the supported durations (1 -- or 3). For example, specify 31536000 for one year. -- -- 'nextToken', 'describeHostReservationOfferings_nextToken' - The token to use to retrieve the next page of results. -- -- 'offeringId', 'describeHostReservationOfferings_offeringId' - The ID of the reservation offering. newDescribeHostReservationOfferings :: DescribeHostReservationOfferings newDescribeHostReservationOfferings = DescribeHostReservationOfferings' { filter' = Prelude.Nothing, maxDuration = Prelude.Nothing, maxResults = Prelude.Nothing, minDuration = Prelude.Nothing, nextToken = Prelude.Nothing, offeringId = Prelude.Nothing } -- | The filters. -- -- - @instance-family@ - The instance family of the offering (for -- example, @m4@). -- -- - @payment-option@ - The payment option (@NoUpfront@ | -- @PartialUpfront@ | @AllUpfront@). describeHostReservationOfferings_filter :: Lens.Lens' DescribeHostReservationOfferings (Prelude.Maybe [Filter]) describeHostReservationOfferings_filter = Lens.lens (\DescribeHostReservationOfferings' {filter'} -> filter') (\s@DescribeHostReservationOfferings' {} a -> s {filter' = a} :: DescribeHostReservationOfferings) Prelude.. Lens.mapping Lens.coerced -- | This is the maximum duration of the reservation to purchase, specified -- in seconds. Reservations are available in one-year and three-year terms. -- The number of seconds specified must be the number of seconds in a year -- (365x24x60x60) times one of the supported durations (1 or 3). For -- example, specify 94608000 for three years. describeHostReservationOfferings_maxDuration :: Lens.Lens' DescribeHostReservationOfferings (Prelude.Maybe Prelude.Int) describeHostReservationOfferings_maxDuration = Lens.lens (\DescribeHostReservationOfferings' {maxDuration} -> maxDuration) (\s@DescribeHostReservationOfferings' {} a -> s {maxDuration = a} :: DescribeHostReservationOfferings) -- | The maximum number of results to return for the request in a single -- page. The remaining results can be seen by sending another request with -- the returned @nextToken@ value. This value can be between 5 and 500. If -- @maxResults@ is given a larger value than 500, you receive an error. describeHostReservationOfferings_maxResults :: Lens.Lens' DescribeHostReservationOfferings (Prelude.Maybe Prelude.Natural) describeHostReservationOfferings_maxResults = Lens.lens (\DescribeHostReservationOfferings' {maxResults} -> maxResults) (\s@DescribeHostReservationOfferings' {} a -> s {maxResults = a} :: DescribeHostReservationOfferings) -- | This is the minimum duration of the reservation you\'d like to purchase, -- specified in seconds. Reservations are available in one-year and -- three-year terms. The number of seconds specified must be the number of -- seconds in a year (365x24x60x60) times one of the supported durations (1 -- or 3). For example, specify 31536000 for one year. describeHostReservationOfferings_minDuration :: Lens.Lens' DescribeHostReservationOfferings (Prelude.Maybe Prelude.Int) describeHostReservationOfferings_minDuration = Lens.lens (\DescribeHostReservationOfferings' {minDuration} -> minDuration) (\s@DescribeHostReservationOfferings' {} a -> s {minDuration = a} :: DescribeHostReservationOfferings) -- | The token to use to retrieve the next page of results. describeHostReservationOfferings_nextToken :: Lens.Lens' DescribeHostReservationOfferings (Prelude.Maybe Prelude.Text) describeHostReservationOfferings_nextToken = Lens.lens (\DescribeHostReservationOfferings' {nextToken} -> nextToken) (\s@DescribeHostReservationOfferings' {} a -> s {nextToken = a} :: DescribeHostReservationOfferings) -- | The ID of the reservation offering. describeHostReservationOfferings_offeringId :: Lens.Lens' DescribeHostReservationOfferings (Prelude.Maybe Prelude.Text) describeHostReservationOfferings_offeringId = Lens.lens (\DescribeHostReservationOfferings' {offeringId} -> offeringId) (\s@DescribeHostReservationOfferings' {} a -> s {offeringId = a} :: DescribeHostReservationOfferings) instance Core.AWSPager DescribeHostReservationOfferings where page rq rs | Core.stop ( rs Lens.^? describeHostReservationOfferingsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? describeHostReservationOfferingsResponse_offeringSet Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& describeHostReservationOfferings_nextToken Lens..~ rs Lens.^? describeHostReservationOfferingsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest DescribeHostReservationOfferings where type AWSResponse DescribeHostReservationOfferings = DescribeHostReservationOfferingsResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXML ( \s h x -> DescribeHostReservationOfferingsResponse' Prelude.<$> (x Data..@? "nextToken") Prelude.<*> ( x Data..@? "offeringSet" Core..!@ Prelude.mempty Prelude.>>= Core.may (Data.parseXMLList "item") ) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DescribeHostReservationOfferings where hashWithSalt _salt DescribeHostReservationOfferings' {..} = _salt `Prelude.hashWithSalt` filter' `Prelude.hashWithSalt` maxDuration `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` minDuration `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` offeringId instance Prelude.NFData DescribeHostReservationOfferings where rnf DescribeHostReservationOfferings' {..} = Prelude.rnf filter' `Prelude.seq` Prelude.rnf maxDuration `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf minDuration `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf offeringId instance Data.ToHeaders DescribeHostReservationOfferings where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath DescribeHostReservationOfferings where toPath = Prelude.const "/" instance Data.ToQuery DescribeHostReservationOfferings where toQuery DescribeHostReservationOfferings' {..} = Prelude.mconcat [ "Action" Data.=: ( "DescribeHostReservationOfferings" :: Prelude.ByteString ), "Version" Data.=: ("2016-11-15" :: Prelude.ByteString), Data.toQuery (Data.toQueryList "Filter" Prelude.<$> filter'), "MaxDuration" Data.=: maxDuration, "MaxResults" Data.=: maxResults, "MinDuration" Data.=: minDuration, "NextToken" Data.=: nextToken, "OfferingId" Data.=: offeringId ] -- | /See:/ 'newDescribeHostReservationOfferingsResponse' smart constructor. data DescribeHostReservationOfferingsResponse = DescribeHostReservationOfferingsResponse' { -- | The token to use to retrieve the next page of results. This value is -- @null@ when there are no more results to return. nextToken :: Prelude.Maybe Prelude.Text, -- | Information about the offerings. offeringSet :: Prelude.Maybe [HostOffering], -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeHostReservationOfferingsResponse' 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: -- -- 'nextToken', 'describeHostReservationOfferingsResponse_nextToken' - The token to use to retrieve the next page of results. This value is -- @null@ when there are no more results to return. -- -- 'offeringSet', 'describeHostReservationOfferingsResponse_offeringSet' - Information about the offerings. -- -- 'httpStatus', 'describeHostReservationOfferingsResponse_httpStatus' - The response's http status code. newDescribeHostReservationOfferingsResponse :: -- | 'httpStatus' Prelude.Int -> DescribeHostReservationOfferingsResponse newDescribeHostReservationOfferingsResponse pHttpStatus_ = DescribeHostReservationOfferingsResponse' { nextToken = Prelude.Nothing, offeringSet = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The token to use to retrieve the next page of results. This value is -- @null@ when there are no more results to return. describeHostReservationOfferingsResponse_nextToken :: Lens.Lens' DescribeHostReservationOfferingsResponse (Prelude.Maybe Prelude.Text) describeHostReservationOfferingsResponse_nextToken = Lens.lens (\DescribeHostReservationOfferingsResponse' {nextToken} -> nextToken) (\s@DescribeHostReservationOfferingsResponse' {} a -> s {nextToken = a} :: DescribeHostReservationOfferingsResponse) -- | Information about the offerings. describeHostReservationOfferingsResponse_offeringSet :: Lens.Lens' DescribeHostReservationOfferingsResponse (Prelude.Maybe [HostOffering]) describeHostReservationOfferingsResponse_offeringSet = Lens.lens (\DescribeHostReservationOfferingsResponse' {offeringSet} -> offeringSet) (\s@DescribeHostReservationOfferingsResponse' {} a -> s {offeringSet = a} :: DescribeHostReservationOfferingsResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. describeHostReservationOfferingsResponse_httpStatus :: Lens.Lens' DescribeHostReservationOfferingsResponse Prelude.Int describeHostReservationOfferingsResponse_httpStatus = Lens.lens (\DescribeHostReservationOfferingsResponse' {httpStatus} -> httpStatus) (\s@DescribeHostReservationOfferingsResponse' {} a -> s {httpStatus = a} :: DescribeHostReservationOfferingsResponse) instance Prelude.NFData DescribeHostReservationOfferingsResponse where rnf DescribeHostReservationOfferingsResponse' {..} = Prelude.rnf nextToken `Prelude.seq` Prelude.rnf offeringSet `Prelude.seq` Prelude.rnf httpStatus