{-# 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.Kendra.ListGroupsOlderThanOrderingId -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Provides a list of groups that are mapped to users before a given -- ordering or timestamp identifier. -- -- @ListGroupsOlderThanOrderingId@ is currently not supported in the Amazon -- Web Services GovCloud (US-West) region. module Amazonka.Kendra.ListGroupsOlderThanOrderingId ( -- * Creating a Request ListGroupsOlderThanOrderingId (..), newListGroupsOlderThanOrderingId, -- * Request Lenses listGroupsOlderThanOrderingId_dataSourceId, listGroupsOlderThanOrderingId_maxResults, listGroupsOlderThanOrderingId_nextToken, listGroupsOlderThanOrderingId_indexId, listGroupsOlderThanOrderingId_orderingId, -- * Destructuring the Response ListGroupsOlderThanOrderingIdResponse (..), newListGroupsOlderThanOrderingIdResponse, -- * Response Lenses listGroupsOlderThanOrderingIdResponse_groupsSummaries, listGroupsOlderThanOrderingIdResponse_nextToken, listGroupsOlderThanOrderingIdResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.Kendra.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newListGroupsOlderThanOrderingId' smart constructor. data ListGroupsOlderThanOrderingId = ListGroupsOlderThanOrderingId' { -- | The identifier of the data source for getting a list of groups mapped to -- users before a given ordering timestamp identifier. dataSourceId :: Prelude.Maybe Prelude.Text, -- | The maximum number of returned groups that are mapped to users before a -- given ordering or timestamp identifier. maxResults :: Prelude.Maybe Prelude.Natural, -- | If the previous response was incomplete (because there is more data to -- retrieve), Amazon Kendra returns a pagination token in the response. You -- can use this pagination token to retrieve the next set of groups that -- are mapped to users before a given ordering or timestamp identifier. nextToken :: Prelude.Maybe Prelude.Text, -- | The identifier of the index for getting a list of groups mapped to users -- before a given ordering or timestamp identifier. indexId :: Prelude.Text, -- | The timestamp identifier used for the latest @PUT@ or @DELETE@ action -- for mapping users to their groups. orderingId :: Prelude.Natural } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListGroupsOlderThanOrderingId' 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: -- -- 'dataSourceId', 'listGroupsOlderThanOrderingId_dataSourceId' - The identifier of the data source for getting a list of groups mapped to -- users before a given ordering timestamp identifier. -- -- 'maxResults', 'listGroupsOlderThanOrderingId_maxResults' - The maximum number of returned groups that are mapped to users before a -- given ordering or timestamp identifier. -- -- 'nextToken', 'listGroupsOlderThanOrderingId_nextToken' - If the previous response was incomplete (because there is more data to -- retrieve), Amazon Kendra returns a pagination token in the response. You -- can use this pagination token to retrieve the next set of groups that -- are mapped to users before a given ordering or timestamp identifier. -- -- 'indexId', 'listGroupsOlderThanOrderingId_indexId' - The identifier of the index for getting a list of groups mapped to users -- before a given ordering or timestamp identifier. -- -- 'orderingId', 'listGroupsOlderThanOrderingId_orderingId' - The timestamp identifier used for the latest @PUT@ or @DELETE@ action -- for mapping users to their groups. newListGroupsOlderThanOrderingId :: -- | 'indexId' Prelude.Text -> -- | 'orderingId' Prelude.Natural -> ListGroupsOlderThanOrderingId newListGroupsOlderThanOrderingId pIndexId_ pOrderingId_ = ListGroupsOlderThanOrderingId' { dataSourceId = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing, indexId = pIndexId_, orderingId = pOrderingId_ } -- | The identifier of the data source for getting a list of groups mapped to -- users before a given ordering timestamp identifier. listGroupsOlderThanOrderingId_dataSourceId :: Lens.Lens' ListGroupsOlderThanOrderingId (Prelude.Maybe Prelude.Text) listGroupsOlderThanOrderingId_dataSourceId = Lens.lens (\ListGroupsOlderThanOrderingId' {dataSourceId} -> dataSourceId) (\s@ListGroupsOlderThanOrderingId' {} a -> s {dataSourceId = a} :: ListGroupsOlderThanOrderingId) -- | The maximum number of returned groups that are mapped to users before a -- given ordering or timestamp identifier. listGroupsOlderThanOrderingId_maxResults :: Lens.Lens' ListGroupsOlderThanOrderingId (Prelude.Maybe Prelude.Natural) listGroupsOlderThanOrderingId_maxResults = Lens.lens (\ListGroupsOlderThanOrderingId' {maxResults} -> maxResults) (\s@ListGroupsOlderThanOrderingId' {} a -> s {maxResults = a} :: ListGroupsOlderThanOrderingId) -- | If the previous response was incomplete (because there is more data to -- retrieve), Amazon Kendra returns a pagination token in the response. You -- can use this pagination token to retrieve the next set of groups that -- are mapped to users before a given ordering or timestamp identifier. listGroupsOlderThanOrderingId_nextToken :: Lens.Lens' ListGroupsOlderThanOrderingId (Prelude.Maybe Prelude.Text) listGroupsOlderThanOrderingId_nextToken = Lens.lens (\ListGroupsOlderThanOrderingId' {nextToken} -> nextToken) (\s@ListGroupsOlderThanOrderingId' {} a -> s {nextToken = a} :: ListGroupsOlderThanOrderingId) -- | The identifier of the index for getting a list of groups mapped to users -- before a given ordering or timestamp identifier. listGroupsOlderThanOrderingId_indexId :: Lens.Lens' ListGroupsOlderThanOrderingId Prelude.Text listGroupsOlderThanOrderingId_indexId = Lens.lens (\ListGroupsOlderThanOrderingId' {indexId} -> indexId) (\s@ListGroupsOlderThanOrderingId' {} a -> s {indexId = a} :: ListGroupsOlderThanOrderingId) -- | The timestamp identifier used for the latest @PUT@ or @DELETE@ action -- for mapping users to their groups. listGroupsOlderThanOrderingId_orderingId :: Lens.Lens' ListGroupsOlderThanOrderingId Prelude.Natural listGroupsOlderThanOrderingId_orderingId = Lens.lens (\ListGroupsOlderThanOrderingId' {orderingId} -> orderingId) (\s@ListGroupsOlderThanOrderingId' {} a -> s {orderingId = a} :: ListGroupsOlderThanOrderingId) instance Core.AWSRequest ListGroupsOlderThanOrderingId where type AWSResponse ListGroupsOlderThanOrderingId = ListGroupsOlderThanOrderingIdResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListGroupsOlderThanOrderingIdResponse' Prelude.<$> ( x Data..?> "GroupsSummaries" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "NextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListGroupsOlderThanOrderingId where hashWithSalt _salt ListGroupsOlderThanOrderingId' {..} = _salt `Prelude.hashWithSalt` dataSourceId `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` indexId `Prelude.hashWithSalt` orderingId instance Prelude.NFData ListGroupsOlderThanOrderingId where rnf ListGroupsOlderThanOrderingId' {..} = Prelude.rnf dataSourceId `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf indexId `Prelude.seq` Prelude.rnf orderingId instance Data.ToHeaders ListGroupsOlderThanOrderingId where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AWSKendraFrontendService.ListGroupsOlderThanOrderingId" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListGroupsOlderThanOrderingId where toJSON ListGroupsOlderThanOrderingId' {..} = Data.object ( Prelude.catMaybes [ ("DataSourceId" Data..=) Prelude.<$> dataSourceId, ("MaxResults" Data..=) Prelude.<$> maxResults, ("NextToken" Data..=) Prelude.<$> nextToken, Prelude.Just ("IndexId" Data..= indexId), Prelude.Just ("OrderingId" Data..= orderingId) ] ) instance Data.ToPath ListGroupsOlderThanOrderingId where toPath = Prelude.const "/" instance Data.ToQuery ListGroupsOlderThanOrderingId where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newListGroupsOlderThanOrderingIdResponse' smart constructor. data ListGroupsOlderThanOrderingIdResponse = ListGroupsOlderThanOrderingIdResponse' { -- | Summary information for list of groups that are mapped to users before a -- given ordering or timestamp identifier. groupsSummaries :: Prelude.Maybe [GroupSummary], -- | If the response is truncated, Amazon Kendra returns this token that you -- can use in the subsequent request to retrieve the next set of groups -- that are mapped to users before a given ordering or timestamp -- identifier. 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 'ListGroupsOlderThanOrderingIdResponse' 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: -- -- 'groupsSummaries', 'listGroupsOlderThanOrderingIdResponse_groupsSummaries' - Summary information for list of groups that are mapped to users before a -- given ordering or timestamp identifier. -- -- 'nextToken', 'listGroupsOlderThanOrderingIdResponse_nextToken' - If the response is truncated, Amazon Kendra returns this token that you -- can use in the subsequent request to retrieve the next set of groups -- that are mapped to users before a given ordering or timestamp -- identifier. -- -- 'httpStatus', 'listGroupsOlderThanOrderingIdResponse_httpStatus' - The response's http status code. newListGroupsOlderThanOrderingIdResponse :: -- | 'httpStatus' Prelude.Int -> ListGroupsOlderThanOrderingIdResponse newListGroupsOlderThanOrderingIdResponse pHttpStatus_ = ListGroupsOlderThanOrderingIdResponse' { groupsSummaries = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Summary information for list of groups that are mapped to users before a -- given ordering or timestamp identifier. listGroupsOlderThanOrderingIdResponse_groupsSummaries :: Lens.Lens' ListGroupsOlderThanOrderingIdResponse (Prelude.Maybe [GroupSummary]) listGroupsOlderThanOrderingIdResponse_groupsSummaries = Lens.lens (\ListGroupsOlderThanOrderingIdResponse' {groupsSummaries} -> groupsSummaries) (\s@ListGroupsOlderThanOrderingIdResponse' {} a -> s {groupsSummaries = a} :: ListGroupsOlderThanOrderingIdResponse) Prelude.. Lens.mapping Lens.coerced -- | If the response is truncated, Amazon Kendra returns this token that you -- can use in the subsequent request to retrieve the next set of groups -- that are mapped to users before a given ordering or timestamp -- identifier. listGroupsOlderThanOrderingIdResponse_nextToken :: Lens.Lens' ListGroupsOlderThanOrderingIdResponse (Prelude.Maybe Prelude.Text) listGroupsOlderThanOrderingIdResponse_nextToken = Lens.lens (\ListGroupsOlderThanOrderingIdResponse' {nextToken} -> nextToken) (\s@ListGroupsOlderThanOrderingIdResponse' {} a -> s {nextToken = a} :: ListGroupsOlderThanOrderingIdResponse) -- | The response's http status code. listGroupsOlderThanOrderingIdResponse_httpStatus :: Lens.Lens' ListGroupsOlderThanOrderingIdResponse Prelude.Int listGroupsOlderThanOrderingIdResponse_httpStatus = Lens.lens (\ListGroupsOlderThanOrderingIdResponse' {httpStatus} -> httpStatus) (\s@ListGroupsOlderThanOrderingIdResponse' {} a -> s {httpStatus = a} :: ListGroupsOlderThanOrderingIdResponse) instance Prelude.NFData ListGroupsOlderThanOrderingIdResponse where rnf ListGroupsOlderThanOrderingIdResponse' {..} = Prelude.rnf groupsSummaries `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus