{-# 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.AuditManager.ListAssessmentReports -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Returns a list of assessment reports created in Audit Manager. module Amazonka.AuditManager.ListAssessmentReports ( -- * Creating a Request ListAssessmentReports (..), newListAssessmentReports, -- * Request Lenses listAssessmentReports_maxResults, listAssessmentReports_nextToken, -- * Destructuring the Response ListAssessmentReportsResponse (..), newListAssessmentReportsResponse, -- * Response Lenses listAssessmentReportsResponse_assessmentReports, listAssessmentReportsResponse_nextToken, listAssessmentReportsResponse_httpStatus, ) where import Amazonka.AuditManager.Types 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 -- | /See:/ 'newListAssessmentReports' smart constructor. data ListAssessmentReports = ListAssessmentReports' { -- | Represents the maximum number of results on a page or for an API request -- call. maxResults :: Prelude.Maybe Prelude.Natural, -- | The pagination token that\'s used to fetch the next set of results. nextToken :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListAssessmentReports' 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', 'listAssessmentReports_maxResults' - Represents the maximum number of results on a page or for an API request -- call. -- -- 'nextToken', 'listAssessmentReports_nextToken' - The pagination token that\'s used to fetch the next set of results. newListAssessmentReports :: ListAssessmentReports newListAssessmentReports = ListAssessmentReports' { maxResults = Prelude.Nothing, nextToken = Prelude.Nothing } -- | Represents the maximum number of results on a page or for an API request -- call. listAssessmentReports_maxResults :: Lens.Lens' ListAssessmentReports (Prelude.Maybe Prelude.Natural) listAssessmentReports_maxResults = Lens.lens (\ListAssessmentReports' {maxResults} -> maxResults) (\s@ListAssessmentReports' {} a -> s {maxResults = a} :: ListAssessmentReports) -- | The pagination token that\'s used to fetch the next set of results. listAssessmentReports_nextToken :: Lens.Lens' ListAssessmentReports (Prelude.Maybe Prelude.Text) listAssessmentReports_nextToken = Lens.lens (\ListAssessmentReports' {nextToken} -> nextToken) (\s@ListAssessmentReports' {} a -> s {nextToken = a} :: ListAssessmentReports) instance Core.AWSRequest ListAssessmentReports where type AWSResponse ListAssessmentReports = ListAssessmentReportsResponse request overrides = Request.get (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListAssessmentReportsResponse' Prelude.<$> ( x Data..?> "assessmentReports" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "nextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListAssessmentReports where hashWithSalt _salt ListAssessmentReports' {..} = _salt `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken instance Prelude.NFData ListAssessmentReports where rnf ListAssessmentReports' {..} = Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken instance Data.ToHeaders ListAssessmentReports where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToPath ListAssessmentReports where toPath = Prelude.const "/assessmentReports" instance Data.ToQuery ListAssessmentReports where toQuery ListAssessmentReports' {..} = Prelude.mconcat [ "maxResults" Data.=: maxResults, "nextToken" Data.=: nextToken ] -- | /See:/ 'newListAssessmentReportsResponse' smart constructor. data ListAssessmentReportsResponse = ListAssessmentReportsResponse' { -- | The list of assessment reports that the @ListAssessmentReports@ API -- returned. assessmentReports :: Prelude.Maybe [AssessmentReportMetadata], -- | The pagination token that\'s used to fetch 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 'ListAssessmentReportsResponse' 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: -- -- 'assessmentReports', 'listAssessmentReportsResponse_assessmentReports' - The list of assessment reports that the @ListAssessmentReports@ API -- returned. -- -- 'nextToken', 'listAssessmentReportsResponse_nextToken' - The pagination token that\'s used to fetch the next set of results. -- -- 'httpStatus', 'listAssessmentReportsResponse_httpStatus' - The response's http status code. newListAssessmentReportsResponse :: -- | 'httpStatus' Prelude.Int -> ListAssessmentReportsResponse newListAssessmentReportsResponse pHttpStatus_ = ListAssessmentReportsResponse' { assessmentReports = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The list of assessment reports that the @ListAssessmentReports@ API -- returned. listAssessmentReportsResponse_assessmentReports :: Lens.Lens' ListAssessmentReportsResponse (Prelude.Maybe [AssessmentReportMetadata]) listAssessmentReportsResponse_assessmentReports = Lens.lens (\ListAssessmentReportsResponse' {assessmentReports} -> assessmentReports) (\s@ListAssessmentReportsResponse' {} a -> s {assessmentReports = a} :: ListAssessmentReportsResponse) Prelude.. Lens.mapping Lens.coerced -- | The pagination token that\'s used to fetch the next set of results. listAssessmentReportsResponse_nextToken :: Lens.Lens' ListAssessmentReportsResponse (Prelude.Maybe Prelude.Text) listAssessmentReportsResponse_nextToken = Lens.lens (\ListAssessmentReportsResponse' {nextToken} -> nextToken) (\s@ListAssessmentReportsResponse' {} a -> s {nextToken = a} :: ListAssessmentReportsResponse) -- | The response's http status code. listAssessmentReportsResponse_httpStatus :: Lens.Lens' ListAssessmentReportsResponse Prelude.Int listAssessmentReportsResponse_httpStatus = Lens.lens (\ListAssessmentReportsResponse' {httpStatus} -> httpStatus) (\s@ListAssessmentReportsResponse' {} a -> s {httpStatus = a} :: ListAssessmentReportsResponse) instance Prelude.NFData ListAssessmentReportsResponse where rnf ListAssessmentReportsResponse' {..} = Prelude.rnf assessmentReports `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus