{-# 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.DescribeInstanceCreditSpecifications -- 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 credit option for CPU usage of the specified burstable -- performance instances. The credit options are @standard@ and -- @unlimited@. -- -- If you do not specify an instance ID, Amazon EC2 returns burstable -- performance instances with the @unlimited@ credit option, as well as -- instances that were previously configured as T2, T3, and T3a with the -- @unlimited@ credit option. For example, if you resize a T2 instance, -- while it is configured as @unlimited@, to an M4 instance, Amazon EC2 -- returns the M4 instance. -- -- If you specify one or more instance IDs, Amazon EC2 returns the credit -- option (@standard@ or @unlimited@) of those instances. If you specify an -- instance ID that is not valid, such as an instance that is not a -- burstable performance instance, an error is returned. -- -- Recently terminated instances might appear in the returned results. This -- interval is usually less than one hour. -- -- If an Availability Zone is experiencing a service disruption and you -- specify instance IDs in the affected zone, or do not specify any -- instance IDs at all, the call fails. If you specify only instance IDs in -- an unaffected zone, the call works normally. -- -- For more information, see -- -- in the /Amazon EC2 User Guide/. -- -- This operation returns paginated results. module Amazonka.EC2.DescribeInstanceCreditSpecifications ( -- * Creating a Request DescribeInstanceCreditSpecifications (..), newDescribeInstanceCreditSpecifications, -- * Request Lenses describeInstanceCreditSpecifications_dryRun, describeInstanceCreditSpecifications_filters, describeInstanceCreditSpecifications_instanceIds, describeInstanceCreditSpecifications_maxResults, describeInstanceCreditSpecifications_nextToken, -- * Destructuring the Response DescribeInstanceCreditSpecificationsResponse (..), newDescribeInstanceCreditSpecificationsResponse, -- * Response Lenses describeInstanceCreditSpecificationsResponse_instanceCreditSpecifications, describeInstanceCreditSpecificationsResponse_nextToken, describeInstanceCreditSpecificationsResponse_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:/ 'newDescribeInstanceCreditSpecifications' smart constructor. data DescribeInstanceCreditSpecifications = DescribeInstanceCreditSpecifications' { -- | 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 filters. -- -- - @instance-id@ - The ID of the instance. filters :: Prelude.Maybe [Filter], -- | The instance IDs. -- -- Default: Describes all your instances. -- -- Constraints: Maximum 1000 explicitly specified instance IDs. instanceIds :: Prelude.Maybe [Prelude.Text], -- | The maximum number of results to return in a single call. To retrieve -- the remaining results, make another call with the returned @NextToken@ -- value. This value can be between 5 and 1000. You cannot specify this -- parameter and the instance IDs parameter in the same call. maxResults :: Prelude.Maybe Prelude.Natural, -- | The token to retrieve the next page of results. nextToken :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeInstanceCreditSpecifications' 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', 'describeInstanceCreditSpecifications_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@. -- -- 'filters', 'describeInstanceCreditSpecifications_filters' - The filters. -- -- - @instance-id@ - The ID of the instance. -- -- 'instanceIds', 'describeInstanceCreditSpecifications_instanceIds' - The instance IDs. -- -- Default: Describes all your instances. -- -- Constraints: Maximum 1000 explicitly specified instance IDs. -- -- 'maxResults', 'describeInstanceCreditSpecifications_maxResults' - The maximum number of results to return in a single call. To retrieve -- the remaining results, make another call with the returned @NextToken@ -- value. This value can be between 5 and 1000. You cannot specify this -- parameter and the instance IDs parameter in the same call. -- -- 'nextToken', 'describeInstanceCreditSpecifications_nextToken' - The token to retrieve the next page of results. newDescribeInstanceCreditSpecifications :: DescribeInstanceCreditSpecifications newDescribeInstanceCreditSpecifications = DescribeInstanceCreditSpecifications' { dryRun = Prelude.Nothing, filters = Prelude.Nothing, instanceIds = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing } -- | 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@. describeInstanceCreditSpecifications_dryRun :: Lens.Lens' DescribeInstanceCreditSpecifications (Prelude.Maybe Prelude.Bool) describeInstanceCreditSpecifications_dryRun = Lens.lens (\DescribeInstanceCreditSpecifications' {dryRun} -> dryRun) (\s@DescribeInstanceCreditSpecifications' {} a -> s {dryRun = a} :: DescribeInstanceCreditSpecifications) -- | The filters. -- -- - @instance-id@ - The ID of the instance. describeInstanceCreditSpecifications_filters :: Lens.Lens' DescribeInstanceCreditSpecifications (Prelude.Maybe [Filter]) describeInstanceCreditSpecifications_filters = Lens.lens (\DescribeInstanceCreditSpecifications' {filters} -> filters) (\s@DescribeInstanceCreditSpecifications' {} a -> s {filters = a} :: DescribeInstanceCreditSpecifications) Prelude.. Lens.mapping Lens.coerced -- | The instance IDs. -- -- Default: Describes all your instances. -- -- Constraints: Maximum 1000 explicitly specified instance IDs. describeInstanceCreditSpecifications_instanceIds :: Lens.Lens' DescribeInstanceCreditSpecifications (Prelude.Maybe [Prelude.Text]) describeInstanceCreditSpecifications_instanceIds = Lens.lens (\DescribeInstanceCreditSpecifications' {instanceIds} -> instanceIds) (\s@DescribeInstanceCreditSpecifications' {} a -> s {instanceIds = a} :: DescribeInstanceCreditSpecifications) Prelude.. Lens.mapping Lens.coerced -- | The maximum number of results to return in a single call. To retrieve -- the remaining results, make another call with the returned @NextToken@ -- value. This value can be between 5 and 1000. You cannot specify this -- parameter and the instance IDs parameter in the same call. describeInstanceCreditSpecifications_maxResults :: Lens.Lens' DescribeInstanceCreditSpecifications (Prelude.Maybe Prelude.Natural) describeInstanceCreditSpecifications_maxResults = Lens.lens (\DescribeInstanceCreditSpecifications' {maxResults} -> maxResults) (\s@DescribeInstanceCreditSpecifications' {} a -> s {maxResults = a} :: DescribeInstanceCreditSpecifications) -- | The token to retrieve the next page of results. describeInstanceCreditSpecifications_nextToken :: Lens.Lens' DescribeInstanceCreditSpecifications (Prelude.Maybe Prelude.Text) describeInstanceCreditSpecifications_nextToken = Lens.lens (\DescribeInstanceCreditSpecifications' {nextToken} -> nextToken) (\s@DescribeInstanceCreditSpecifications' {} a -> s {nextToken = a} :: DescribeInstanceCreditSpecifications) instance Core.AWSPager DescribeInstanceCreditSpecifications where page rq rs | Core.stop ( rs Lens.^? describeInstanceCreditSpecificationsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? describeInstanceCreditSpecificationsResponse_instanceCreditSpecifications Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& describeInstanceCreditSpecifications_nextToken Lens..~ rs Lens.^? describeInstanceCreditSpecificationsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest DescribeInstanceCreditSpecifications where type AWSResponse DescribeInstanceCreditSpecifications = DescribeInstanceCreditSpecificationsResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXML ( \s h x -> DescribeInstanceCreditSpecificationsResponse' Prelude.<$> ( x Data..@? "instanceCreditSpecificationSet" Core..!@ Prelude.mempty Prelude.>>= Core.may (Data.parseXMLList "item") ) Prelude.<*> (x Data..@? "nextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DescribeInstanceCreditSpecifications where hashWithSalt _salt DescribeInstanceCreditSpecifications' {..} = _salt `Prelude.hashWithSalt` dryRun `Prelude.hashWithSalt` filters `Prelude.hashWithSalt` instanceIds `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken instance Prelude.NFData DescribeInstanceCreditSpecifications where rnf DescribeInstanceCreditSpecifications' {..} = Prelude.rnf dryRun `Prelude.seq` Prelude.rnf filters `Prelude.seq` Prelude.rnf instanceIds `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken instance Data.ToHeaders DescribeInstanceCreditSpecifications where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath DescribeInstanceCreditSpecifications where toPath = Prelude.const "/" instance Data.ToQuery DescribeInstanceCreditSpecifications where toQuery DescribeInstanceCreditSpecifications' {..} = Prelude.mconcat [ "Action" Data.=: ( "DescribeInstanceCreditSpecifications" :: Prelude.ByteString ), "Version" Data.=: ("2016-11-15" :: Prelude.ByteString), "DryRun" Data.=: dryRun, Data.toQuery (Data.toQueryList "Filter" Prelude.<$> filters), Data.toQuery ( Data.toQueryList "InstanceId" Prelude.<$> instanceIds ), "MaxResults" Data.=: maxResults, "NextToken" Data.=: nextToken ] -- | /See:/ 'newDescribeInstanceCreditSpecificationsResponse' smart constructor. data DescribeInstanceCreditSpecificationsResponse = DescribeInstanceCreditSpecificationsResponse' { -- | Information about the credit option for CPU usage of an instance. instanceCreditSpecifications :: Prelude.Maybe [InstanceCreditSpecification], -- | 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, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeInstanceCreditSpecificationsResponse' 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: -- -- 'instanceCreditSpecifications', 'describeInstanceCreditSpecificationsResponse_instanceCreditSpecifications' - Information about the credit option for CPU usage of an instance. -- -- 'nextToken', 'describeInstanceCreditSpecificationsResponse_nextToken' - The token to use to retrieve the next page of results. This value is -- @null@ when there are no more results to return. -- -- 'httpStatus', 'describeInstanceCreditSpecificationsResponse_httpStatus' - The response's http status code. newDescribeInstanceCreditSpecificationsResponse :: -- | 'httpStatus' Prelude.Int -> DescribeInstanceCreditSpecificationsResponse newDescribeInstanceCreditSpecificationsResponse pHttpStatus_ = DescribeInstanceCreditSpecificationsResponse' { instanceCreditSpecifications = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Information about the credit option for CPU usage of an instance. describeInstanceCreditSpecificationsResponse_instanceCreditSpecifications :: Lens.Lens' DescribeInstanceCreditSpecificationsResponse (Prelude.Maybe [InstanceCreditSpecification]) describeInstanceCreditSpecificationsResponse_instanceCreditSpecifications = Lens.lens (\DescribeInstanceCreditSpecificationsResponse' {instanceCreditSpecifications} -> instanceCreditSpecifications) (\s@DescribeInstanceCreditSpecificationsResponse' {} a -> s {instanceCreditSpecifications = a} :: DescribeInstanceCreditSpecificationsResponse) Prelude.. Lens.mapping Lens.coerced -- | The token to use to retrieve the next page of results. This value is -- @null@ when there are no more results to return. describeInstanceCreditSpecificationsResponse_nextToken :: Lens.Lens' DescribeInstanceCreditSpecificationsResponse (Prelude.Maybe Prelude.Text) describeInstanceCreditSpecificationsResponse_nextToken = Lens.lens (\DescribeInstanceCreditSpecificationsResponse' {nextToken} -> nextToken) (\s@DescribeInstanceCreditSpecificationsResponse' {} a -> s {nextToken = a} :: DescribeInstanceCreditSpecificationsResponse) -- | The response's http status code. describeInstanceCreditSpecificationsResponse_httpStatus :: Lens.Lens' DescribeInstanceCreditSpecificationsResponse Prelude.Int describeInstanceCreditSpecificationsResponse_httpStatus = Lens.lens (\DescribeInstanceCreditSpecificationsResponse' {httpStatus} -> httpStatus) (\s@DescribeInstanceCreditSpecificationsResponse' {} a -> s {httpStatus = a} :: DescribeInstanceCreditSpecificationsResponse) instance Prelude.NFData DescribeInstanceCreditSpecificationsResponse where rnf DescribeInstanceCreditSpecificationsResponse' {..} = Prelude.rnf instanceCreditSpecifications `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus