{-# 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.LookoutMetrics.ListAnomalyDetectors -- 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 the detectors in the current AWS Region. -- -- Amazon Lookout for Metrics API actions are eventually consistent. If you -- do a read operation on a resource immediately after creating or -- modifying it, use retries to allow time for the write operation to -- complete. module Amazonka.LookoutMetrics.ListAnomalyDetectors ( -- * Creating a Request ListAnomalyDetectors (..), newListAnomalyDetectors, -- * Request Lenses listAnomalyDetectors_maxResults, listAnomalyDetectors_nextToken, -- * Destructuring the Response ListAnomalyDetectorsResponse (..), newListAnomalyDetectorsResponse, -- * Response Lenses listAnomalyDetectorsResponse_anomalyDetectorSummaryList, listAnomalyDetectorsResponse_nextToken, listAnomalyDetectorsResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.LookoutMetrics.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newListAnomalyDetectors' smart constructor. data ListAnomalyDetectors = ListAnomalyDetectors' { -- | The maximum number of results to return. maxResults :: Prelude.Maybe Prelude.Natural, -- | If the result of the previous request was truncated, the response -- includes a @NextToken@. To retrieve the next set of results, use the -- token in the next request. Tokens expire after 24 hours. nextToken :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListAnomalyDetectors' 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: -- -- 'maxResults', 'listAnomalyDetectors_maxResults' - The maximum number of results to return. -- -- 'nextToken', 'listAnomalyDetectors_nextToken' - If the result of the previous request was truncated, the response -- includes a @NextToken@. To retrieve the next set of results, use the -- token in the next request. Tokens expire after 24 hours. newListAnomalyDetectors :: ListAnomalyDetectors newListAnomalyDetectors = ListAnomalyDetectors' { maxResults = Prelude.Nothing, nextToken = Prelude.Nothing } -- | The maximum number of results to return. listAnomalyDetectors_maxResults :: Lens.Lens' ListAnomalyDetectors (Prelude.Maybe Prelude.Natural) listAnomalyDetectors_maxResults = Lens.lens (\ListAnomalyDetectors' {maxResults} -> maxResults) (\s@ListAnomalyDetectors' {} a -> s {maxResults = a} :: ListAnomalyDetectors) -- | If the result of the previous request was truncated, the response -- includes a @NextToken@. To retrieve the next set of results, use the -- token in the next request. Tokens expire after 24 hours. listAnomalyDetectors_nextToken :: Lens.Lens' ListAnomalyDetectors (Prelude.Maybe Prelude.Text) listAnomalyDetectors_nextToken = Lens.lens (\ListAnomalyDetectors' {nextToken} -> nextToken) (\s@ListAnomalyDetectors' {} a -> s {nextToken = a} :: ListAnomalyDetectors) instance Core.AWSRequest ListAnomalyDetectors where type AWSResponse ListAnomalyDetectors = ListAnomalyDetectorsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListAnomalyDetectorsResponse' Prelude.<$> ( x Data..?> "AnomalyDetectorSummaryList" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "NextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListAnomalyDetectors where hashWithSalt _salt ListAnomalyDetectors' {..} = _salt `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken instance Prelude.NFData ListAnomalyDetectors where rnf ListAnomalyDetectors' {..} = Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken instance Data.ToHeaders ListAnomalyDetectors where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListAnomalyDetectors where toJSON ListAnomalyDetectors' {..} = Data.object ( Prelude.catMaybes [ ("MaxResults" Data..=) Prelude.<$> maxResults, ("NextToken" Data..=) Prelude.<$> nextToken ] ) instance Data.ToPath ListAnomalyDetectors where toPath = Prelude.const "/ListAnomalyDetectors" instance Data.ToQuery ListAnomalyDetectors where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newListAnomalyDetectorsResponse' smart constructor. data ListAnomalyDetectorsResponse = ListAnomalyDetectorsResponse' { -- | A list of anomaly detectors in the account in the current region. anomalyDetectorSummaryList :: Prelude.Maybe [AnomalyDetectorSummary], -- | If the response is truncated, the service returns this token. To -- retrieve the next set of results, use the token in the next request. 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 'ListAnomalyDetectorsResponse' 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: -- -- 'anomalyDetectorSummaryList', 'listAnomalyDetectorsResponse_anomalyDetectorSummaryList' - A list of anomaly detectors in the account in the current region. -- -- 'nextToken', 'listAnomalyDetectorsResponse_nextToken' - If the response is truncated, the service returns this token. To -- retrieve the next set of results, use the token in the next request. -- -- 'httpStatus', 'listAnomalyDetectorsResponse_httpStatus' - The response's http status code. newListAnomalyDetectorsResponse :: -- | 'httpStatus' Prelude.Int -> ListAnomalyDetectorsResponse newListAnomalyDetectorsResponse pHttpStatus_ = ListAnomalyDetectorsResponse' { anomalyDetectorSummaryList = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | A list of anomaly detectors in the account in the current region. listAnomalyDetectorsResponse_anomalyDetectorSummaryList :: Lens.Lens' ListAnomalyDetectorsResponse (Prelude.Maybe [AnomalyDetectorSummary]) listAnomalyDetectorsResponse_anomalyDetectorSummaryList = Lens.lens (\ListAnomalyDetectorsResponse' {anomalyDetectorSummaryList} -> anomalyDetectorSummaryList) (\s@ListAnomalyDetectorsResponse' {} a -> s {anomalyDetectorSummaryList = a} :: ListAnomalyDetectorsResponse) Prelude.. Lens.mapping Lens.coerced -- | If the response is truncated, the service returns this token. To -- retrieve the next set of results, use the token in the next request. listAnomalyDetectorsResponse_nextToken :: Lens.Lens' ListAnomalyDetectorsResponse (Prelude.Maybe Prelude.Text) listAnomalyDetectorsResponse_nextToken = Lens.lens (\ListAnomalyDetectorsResponse' {nextToken} -> nextToken) (\s@ListAnomalyDetectorsResponse' {} a -> s {nextToken = a} :: ListAnomalyDetectorsResponse) -- | The response's http status code. listAnomalyDetectorsResponse_httpStatus :: Lens.Lens' ListAnomalyDetectorsResponse Prelude.Int listAnomalyDetectorsResponse_httpStatus = Lens.lens (\ListAnomalyDetectorsResponse' {httpStatus} -> httpStatus) (\s@ListAnomalyDetectorsResponse' {} a -> s {httpStatus = a} :: ListAnomalyDetectorsResponse) instance Prelude.NFData ListAnomalyDetectorsResponse where rnf ListAnomalyDetectorsResponse' {..} = Prelude.rnf anomalyDetectorSummaryList `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus