{-# 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.LookoutEquipment.ListDatasets -- 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 datasets currently available in your account, filtering on the -- dataset name. module Amazonka.LookoutEquipment.ListDatasets ( -- * Creating a Request ListDatasets (..), newListDatasets, -- * Request Lenses listDatasets_datasetNameBeginsWith, listDatasets_maxResults, listDatasets_nextToken, -- * Destructuring the Response ListDatasetsResponse (..), newListDatasetsResponse, -- * Response Lenses listDatasetsResponse_datasetSummaries, listDatasetsResponse_nextToken, listDatasetsResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.LookoutEquipment.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newListDatasets' smart constructor. data ListDatasets = ListDatasets' { -- | The beginning of the name of the datasets to be listed. datasetNameBeginsWith :: Prelude.Maybe Prelude.Text, -- | Specifies the maximum number of datasets to list. maxResults :: Prelude.Maybe Prelude.Natural, -- | An opaque pagination token indicating where to continue the listing of -- datasets. nextToken :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListDatasets' 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: -- -- 'datasetNameBeginsWith', 'listDatasets_datasetNameBeginsWith' - The beginning of the name of the datasets to be listed. -- -- 'maxResults', 'listDatasets_maxResults' - Specifies the maximum number of datasets to list. -- -- 'nextToken', 'listDatasets_nextToken' - An opaque pagination token indicating where to continue the listing of -- datasets. newListDatasets :: ListDatasets newListDatasets = ListDatasets' { datasetNameBeginsWith = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing } -- | The beginning of the name of the datasets to be listed. listDatasets_datasetNameBeginsWith :: Lens.Lens' ListDatasets (Prelude.Maybe Prelude.Text) listDatasets_datasetNameBeginsWith = Lens.lens (\ListDatasets' {datasetNameBeginsWith} -> datasetNameBeginsWith) (\s@ListDatasets' {} a -> s {datasetNameBeginsWith = a} :: ListDatasets) -- | Specifies the maximum number of datasets to list. listDatasets_maxResults :: Lens.Lens' ListDatasets (Prelude.Maybe Prelude.Natural) listDatasets_maxResults = Lens.lens (\ListDatasets' {maxResults} -> maxResults) (\s@ListDatasets' {} a -> s {maxResults = a} :: ListDatasets) -- | An opaque pagination token indicating where to continue the listing of -- datasets. listDatasets_nextToken :: Lens.Lens' ListDatasets (Prelude.Maybe Prelude.Text) listDatasets_nextToken = Lens.lens (\ListDatasets' {nextToken} -> nextToken) (\s@ListDatasets' {} a -> s {nextToken = a} :: ListDatasets) instance Core.AWSRequest ListDatasets where type AWSResponse ListDatasets = ListDatasetsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListDatasetsResponse' Prelude.<$> ( x Data..?> "DatasetSummaries" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "NextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListDatasets where hashWithSalt _salt ListDatasets' {..} = _salt `Prelude.hashWithSalt` datasetNameBeginsWith `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken instance Prelude.NFData ListDatasets where rnf ListDatasets' {..} = Prelude.rnf datasetNameBeginsWith `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken instance Data.ToHeaders ListDatasets where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AWSLookoutEquipmentFrontendService.ListDatasets" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.0" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListDatasets where toJSON ListDatasets' {..} = Data.object ( Prelude.catMaybes [ ("DatasetNameBeginsWith" Data..=) Prelude.<$> datasetNameBeginsWith, ("MaxResults" Data..=) Prelude.<$> maxResults, ("NextToken" Data..=) Prelude.<$> nextToken ] ) instance Data.ToPath ListDatasets where toPath = Prelude.const "/" instance Data.ToQuery ListDatasets where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newListDatasetsResponse' smart constructor. data ListDatasetsResponse = ListDatasetsResponse' { -- | Provides information about the specified dataset, including creation -- time, dataset ARN, and status. datasetSummaries :: Prelude.Maybe [DatasetSummary], -- | An opaque pagination token indicating where to continue the listing of -- datasets. 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 'ListDatasetsResponse' 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: -- -- 'datasetSummaries', 'listDatasetsResponse_datasetSummaries' - Provides information about the specified dataset, including creation -- time, dataset ARN, and status. -- -- 'nextToken', 'listDatasetsResponse_nextToken' - An opaque pagination token indicating where to continue the listing of -- datasets. -- -- 'httpStatus', 'listDatasetsResponse_httpStatus' - The response's http status code. newListDatasetsResponse :: -- | 'httpStatus' Prelude.Int -> ListDatasetsResponse newListDatasetsResponse pHttpStatus_ = ListDatasetsResponse' { datasetSummaries = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Provides information about the specified dataset, including creation -- time, dataset ARN, and status. listDatasetsResponse_datasetSummaries :: Lens.Lens' ListDatasetsResponse (Prelude.Maybe [DatasetSummary]) listDatasetsResponse_datasetSummaries = Lens.lens (\ListDatasetsResponse' {datasetSummaries} -> datasetSummaries) (\s@ListDatasetsResponse' {} a -> s {datasetSummaries = a} :: ListDatasetsResponse) Prelude.. Lens.mapping Lens.coerced -- | An opaque pagination token indicating where to continue the listing of -- datasets. listDatasetsResponse_nextToken :: Lens.Lens' ListDatasetsResponse (Prelude.Maybe Prelude.Text) listDatasetsResponse_nextToken = Lens.lens (\ListDatasetsResponse' {nextToken} -> nextToken) (\s@ListDatasetsResponse' {} a -> s {nextToken = a} :: ListDatasetsResponse) -- | The response's http status code. listDatasetsResponse_httpStatus :: Lens.Lens' ListDatasetsResponse Prelude.Int listDatasetsResponse_httpStatus = Lens.lens (\ListDatasetsResponse' {httpStatus} -> httpStatus) (\s@ListDatasetsResponse' {} a -> s {httpStatus = a} :: ListDatasetsResponse) instance Prelude.NFData ListDatasetsResponse where rnf ListDatasetsResponse' {..} = Prelude.rnf datasetSummaries `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus