{-# 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.Personalize.ListFilters -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Lists all filters that belong to a given dataset group. -- -- This operation returns paginated results. module Amazonka.Personalize.ListFilters ( -- * Creating a Request ListFilters (..), newListFilters, -- * Request Lenses listFilters_datasetGroupArn, listFilters_maxResults, listFilters_nextToken, -- * Destructuring the Response ListFiltersResponse (..), newListFiltersResponse, -- * Response Lenses listFiltersResponse_filters, listFiltersResponse_nextToken, listFiltersResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.Personalize.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newListFilters' smart constructor. data ListFilters = ListFilters' { -- | The ARN of the dataset group that contains the filters. datasetGroupArn :: Prelude.Maybe Prelude.Text, -- | The maximum number of filters to return. maxResults :: Prelude.Maybe Prelude.Natural, -- | A token returned from the previous call to @ListFilters@ for getting the -- next set of filters (if they exist). nextToken :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListFilters' 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: -- -- 'datasetGroupArn', 'listFilters_datasetGroupArn' - The ARN of the dataset group that contains the filters. -- -- 'maxResults', 'listFilters_maxResults' - The maximum number of filters to return. -- -- 'nextToken', 'listFilters_nextToken' - A token returned from the previous call to @ListFilters@ for getting the -- next set of filters (if they exist). newListFilters :: ListFilters newListFilters = ListFilters' { datasetGroupArn = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing } -- | The ARN of the dataset group that contains the filters. listFilters_datasetGroupArn :: Lens.Lens' ListFilters (Prelude.Maybe Prelude.Text) listFilters_datasetGroupArn = Lens.lens (\ListFilters' {datasetGroupArn} -> datasetGroupArn) (\s@ListFilters' {} a -> s {datasetGroupArn = a} :: ListFilters) -- | The maximum number of filters to return. listFilters_maxResults :: Lens.Lens' ListFilters (Prelude.Maybe Prelude.Natural) listFilters_maxResults = Lens.lens (\ListFilters' {maxResults} -> maxResults) (\s@ListFilters' {} a -> s {maxResults = a} :: ListFilters) -- | A token returned from the previous call to @ListFilters@ for getting the -- next set of filters (if they exist). listFilters_nextToken :: Lens.Lens' ListFilters (Prelude.Maybe Prelude.Text) listFilters_nextToken = Lens.lens (\ListFilters' {nextToken} -> nextToken) (\s@ListFilters' {} a -> s {nextToken = a} :: ListFilters) instance Core.AWSPager ListFilters where page rq rs | Core.stop ( rs Lens.^? listFiltersResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? listFiltersResponse_filters Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& listFilters_nextToken Lens..~ rs Lens.^? listFiltersResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest ListFilters where type AWSResponse ListFilters = ListFiltersResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListFiltersResponse' Prelude.<$> (x Data..?> "Filters" Core..!@ Prelude.mempty) Prelude.<*> (x Data..?> "nextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListFilters where hashWithSalt _salt ListFilters' {..} = _salt `Prelude.hashWithSalt` datasetGroupArn `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken instance Prelude.NFData ListFilters where rnf ListFilters' {..} = Prelude.rnf datasetGroupArn `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken instance Data.ToHeaders ListFilters where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AmazonPersonalize.ListFilters" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListFilters where toJSON ListFilters' {..} = Data.object ( Prelude.catMaybes [ ("datasetGroupArn" Data..=) Prelude.<$> datasetGroupArn, ("maxResults" Data..=) Prelude.<$> maxResults, ("nextToken" Data..=) Prelude.<$> nextToken ] ) instance Data.ToPath ListFilters where toPath = Prelude.const "/" instance Data.ToQuery ListFilters where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newListFiltersResponse' smart constructor. data ListFiltersResponse = ListFiltersResponse' { -- | A list of returned filters. filters :: Prelude.Maybe [FilterSummary], -- | A token for getting the next set of filters (if they exist). 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 'ListFiltersResponse' 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: -- -- 'filters', 'listFiltersResponse_filters' - A list of returned filters. -- -- 'nextToken', 'listFiltersResponse_nextToken' - A token for getting the next set of filters (if they exist). -- -- 'httpStatus', 'listFiltersResponse_httpStatus' - The response's http status code. newListFiltersResponse :: -- | 'httpStatus' Prelude.Int -> ListFiltersResponse newListFiltersResponse pHttpStatus_ = ListFiltersResponse' { filters = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | A list of returned filters. listFiltersResponse_filters :: Lens.Lens' ListFiltersResponse (Prelude.Maybe [FilterSummary]) listFiltersResponse_filters = Lens.lens (\ListFiltersResponse' {filters} -> filters) (\s@ListFiltersResponse' {} a -> s {filters = a} :: ListFiltersResponse) Prelude.. Lens.mapping Lens.coerced -- | A token for getting the next set of filters (if they exist). listFiltersResponse_nextToken :: Lens.Lens' ListFiltersResponse (Prelude.Maybe Prelude.Text) listFiltersResponse_nextToken = Lens.lens (\ListFiltersResponse' {nextToken} -> nextToken) (\s@ListFiltersResponse' {} a -> s {nextToken = a} :: ListFiltersResponse) -- | The response's http status code. listFiltersResponse_httpStatus :: Lens.Lens' ListFiltersResponse Prelude.Int listFiltersResponse_httpStatus = Lens.lens (\ListFiltersResponse' {httpStatus} -> httpStatus) (\s@ListFiltersResponse' {} a -> s {httpStatus = a} :: ListFiltersResponse) instance Prelude.NFData ListFiltersResponse where rnf ListFiltersResponse' {..} = Prelude.rnf filters `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus