{-# 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.SSM.DescribeInventoryDeletions -- 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 a specific delete inventory operation. -- -- This operation returns paginated results. module Amazonka.SSM.DescribeInventoryDeletions ( -- * Creating a Request DescribeInventoryDeletions (..), newDescribeInventoryDeletions, -- * Request Lenses describeInventoryDeletions_deletionId, describeInventoryDeletions_maxResults, describeInventoryDeletions_nextToken, -- * Destructuring the Response DescribeInventoryDeletionsResponse (..), newDescribeInventoryDeletionsResponse, -- * Response Lenses describeInventoryDeletionsResponse_inventoryDeletions, describeInventoryDeletionsResponse_nextToken, describeInventoryDeletionsResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response import Amazonka.SSM.Types -- | /See:/ 'newDescribeInventoryDeletions' smart constructor. data DescribeInventoryDeletions = DescribeInventoryDeletions' { -- | Specify the delete inventory ID for which you want information. This ID -- was returned by the @DeleteInventory@ operation. deletionId :: Prelude.Maybe Prelude.Text, -- | The maximum number of items to return for this call. The call also -- returns a token that you can specify in a subsequent call to get the -- next set of results. maxResults :: Prelude.Maybe Prelude.Natural, -- | A token to start the list. Use this token to get the next set of -- results. nextToken :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeInventoryDeletions' 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: -- -- 'deletionId', 'describeInventoryDeletions_deletionId' - Specify the delete inventory ID for which you want information. This ID -- was returned by the @DeleteInventory@ operation. -- -- 'maxResults', 'describeInventoryDeletions_maxResults' - The maximum number of items to return for this call. The call also -- returns a token that you can specify in a subsequent call to get the -- next set of results. -- -- 'nextToken', 'describeInventoryDeletions_nextToken' - A token to start the list. Use this token to get the next set of -- results. newDescribeInventoryDeletions :: DescribeInventoryDeletions newDescribeInventoryDeletions = DescribeInventoryDeletions' { deletionId = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing } -- | Specify the delete inventory ID for which you want information. This ID -- was returned by the @DeleteInventory@ operation. describeInventoryDeletions_deletionId :: Lens.Lens' DescribeInventoryDeletions (Prelude.Maybe Prelude.Text) describeInventoryDeletions_deletionId = Lens.lens (\DescribeInventoryDeletions' {deletionId} -> deletionId) (\s@DescribeInventoryDeletions' {} a -> s {deletionId = a} :: DescribeInventoryDeletions) -- | The maximum number of items to return for this call. The call also -- returns a token that you can specify in a subsequent call to get the -- next set of results. describeInventoryDeletions_maxResults :: Lens.Lens' DescribeInventoryDeletions (Prelude.Maybe Prelude.Natural) describeInventoryDeletions_maxResults = Lens.lens (\DescribeInventoryDeletions' {maxResults} -> maxResults) (\s@DescribeInventoryDeletions' {} a -> s {maxResults = a} :: DescribeInventoryDeletions) -- | A token to start the list. Use this token to get the next set of -- results. describeInventoryDeletions_nextToken :: Lens.Lens' DescribeInventoryDeletions (Prelude.Maybe Prelude.Text) describeInventoryDeletions_nextToken = Lens.lens (\DescribeInventoryDeletions' {nextToken} -> nextToken) (\s@DescribeInventoryDeletions' {} a -> s {nextToken = a} :: DescribeInventoryDeletions) instance Core.AWSPager DescribeInventoryDeletions where page rq rs | Core.stop ( rs Lens.^? describeInventoryDeletionsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? describeInventoryDeletionsResponse_inventoryDeletions Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& describeInventoryDeletions_nextToken Lens..~ rs Lens.^? describeInventoryDeletionsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest DescribeInventoryDeletions where type AWSResponse DescribeInventoryDeletions = DescribeInventoryDeletionsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DescribeInventoryDeletionsResponse' Prelude.<$> ( x Data..?> "InventoryDeletions" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "NextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DescribeInventoryDeletions where hashWithSalt _salt DescribeInventoryDeletions' {..} = _salt `Prelude.hashWithSalt` deletionId `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken instance Prelude.NFData DescribeInventoryDeletions where rnf DescribeInventoryDeletions' {..} = Prelude.rnf deletionId `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken instance Data.ToHeaders DescribeInventoryDeletions where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AmazonSSM.DescribeInventoryDeletions" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DescribeInventoryDeletions where toJSON DescribeInventoryDeletions' {..} = Data.object ( Prelude.catMaybes [ ("DeletionId" Data..=) Prelude.<$> deletionId, ("MaxResults" Data..=) Prelude.<$> maxResults, ("NextToken" Data..=) Prelude.<$> nextToken ] ) instance Data.ToPath DescribeInventoryDeletions where toPath = Prelude.const "/" instance Data.ToQuery DescribeInventoryDeletions where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDescribeInventoryDeletionsResponse' smart constructor. data DescribeInventoryDeletionsResponse = DescribeInventoryDeletionsResponse' { -- | A list of status items for deleted inventory. inventoryDeletions :: Prelude.Maybe [InventoryDeletionStatusItem], -- | The token for the next set of items to return. Use this token to get the -- next set of results. 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 'DescribeInventoryDeletionsResponse' 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: -- -- 'inventoryDeletions', 'describeInventoryDeletionsResponse_inventoryDeletions' - A list of status items for deleted inventory. -- -- 'nextToken', 'describeInventoryDeletionsResponse_nextToken' - The token for the next set of items to return. Use this token to get the -- next set of results. -- -- 'httpStatus', 'describeInventoryDeletionsResponse_httpStatus' - The response's http status code. newDescribeInventoryDeletionsResponse :: -- | 'httpStatus' Prelude.Int -> DescribeInventoryDeletionsResponse newDescribeInventoryDeletionsResponse pHttpStatus_ = DescribeInventoryDeletionsResponse' { inventoryDeletions = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | A list of status items for deleted inventory. describeInventoryDeletionsResponse_inventoryDeletions :: Lens.Lens' DescribeInventoryDeletionsResponse (Prelude.Maybe [InventoryDeletionStatusItem]) describeInventoryDeletionsResponse_inventoryDeletions = Lens.lens (\DescribeInventoryDeletionsResponse' {inventoryDeletions} -> inventoryDeletions) (\s@DescribeInventoryDeletionsResponse' {} a -> s {inventoryDeletions = a} :: DescribeInventoryDeletionsResponse) Prelude.. Lens.mapping Lens.coerced -- | The token for the next set of items to return. Use this token to get the -- next set of results. describeInventoryDeletionsResponse_nextToken :: Lens.Lens' DescribeInventoryDeletionsResponse (Prelude.Maybe Prelude.Text) describeInventoryDeletionsResponse_nextToken = Lens.lens (\DescribeInventoryDeletionsResponse' {nextToken} -> nextToken) (\s@DescribeInventoryDeletionsResponse' {} a -> s {nextToken = a} :: DescribeInventoryDeletionsResponse) -- | The response's http status code. describeInventoryDeletionsResponse_httpStatus :: Lens.Lens' DescribeInventoryDeletionsResponse Prelude.Int describeInventoryDeletionsResponse_httpStatus = Lens.lens (\DescribeInventoryDeletionsResponse' {httpStatus} -> httpStatus) (\s@DescribeInventoryDeletionsResponse' {} a -> s {httpStatus = a} :: DescribeInventoryDeletionsResponse) instance Prelude.NFData DescribeInventoryDeletionsResponse where rnf DescribeInventoryDeletionsResponse' {..} = Prelude.rnf inventoryDeletions `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus