{-# 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.Comprehend.ListPiiEntitiesDetectionJobs -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Gets a list of the PII entity detection jobs that you have submitted. -- -- This operation returns paginated results. module Amazonka.Comprehend.ListPiiEntitiesDetectionJobs ( -- * Creating a Request ListPiiEntitiesDetectionJobs (..), newListPiiEntitiesDetectionJobs, -- * Request Lenses listPiiEntitiesDetectionJobs_filter, listPiiEntitiesDetectionJobs_maxResults, listPiiEntitiesDetectionJobs_nextToken, -- * Destructuring the Response ListPiiEntitiesDetectionJobsResponse (..), newListPiiEntitiesDetectionJobsResponse, -- * Response Lenses listPiiEntitiesDetectionJobsResponse_nextToken, listPiiEntitiesDetectionJobsResponse_piiEntitiesDetectionJobPropertiesList, listPiiEntitiesDetectionJobsResponse_httpStatus, ) where import Amazonka.Comprehend.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:/ 'newListPiiEntitiesDetectionJobs' smart constructor. data ListPiiEntitiesDetectionJobs = ListPiiEntitiesDetectionJobs' { -- | Filters the jobs that are returned. You can filter jobs on their name, -- status, or the date and time that they were submitted. You can only set -- one filter at a time. filter' :: Prelude.Maybe PiiEntitiesDetectionJobFilter, -- | The maximum number of results to return in each page. maxResults :: Prelude.Maybe Prelude.Natural, -- | Identifies the next page of results to return. nextToken :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListPiiEntitiesDetectionJobs' 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: -- -- 'filter'', 'listPiiEntitiesDetectionJobs_filter' - Filters the jobs that are returned. You can filter jobs on their name, -- status, or the date and time that they were submitted. You can only set -- one filter at a time. -- -- 'maxResults', 'listPiiEntitiesDetectionJobs_maxResults' - The maximum number of results to return in each page. -- -- 'nextToken', 'listPiiEntitiesDetectionJobs_nextToken' - Identifies the next page of results to return. newListPiiEntitiesDetectionJobs :: ListPiiEntitiesDetectionJobs newListPiiEntitiesDetectionJobs = ListPiiEntitiesDetectionJobs' { filter' = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing } -- | Filters the jobs that are returned. You can filter jobs on their name, -- status, or the date and time that they were submitted. You can only set -- one filter at a time. listPiiEntitiesDetectionJobs_filter :: Lens.Lens' ListPiiEntitiesDetectionJobs (Prelude.Maybe PiiEntitiesDetectionJobFilter) listPiiEntitiesDetectionJobs_filter = Lens.lens (\ListPiiEntitiesDetectionJobs' {filter'} -> filter') (\s@ListPiiEntitiesDetectionJobs' {} a -> s {filter' = a} :: ListPiiEntitiesDetectionJobs) -- | The maximum number of results to return in each page. listPiiEntitiesDetectionJobs_maxResults :: Lens.Lens' ListPiiEntitiesDetectionJobs (Prelude.Maybe Prelude.Natural) listPiiEntitiesDetectionJobs_maxResults = Lens.lens (\ListPiiEntitiesDetectionJobs' {maxResults} -> maxResults) (\s@ListPiiEntitiesDetectionJobs' {} a -> s {maxResults = a} :: ListPiiEntitiesDetectionJobs) -- | Identifies the next page of results to return. listPiiEntitiesDetectionJobs_nextToken :: Lens.Lens' ListPiiEntitiesDetectionJobs (Prelude.Maybe Prelude.Text) listPiiEntitiesDetectionJobs_nextToken = Lens.lens (\ListPiiEntitiesDetectionJobs' {nextToken} -> nextToken) (\s@ListPiiEntitiesDetectionJobs' {} a -> s {nextToken = a} :: ListPiiEntitiesDetectionJobs) instance Core.AWSPager ListPiiEntitiesDetectionJobs where page rq rs | Core.stop ( rs Lens.^? listPiiEntitiesDetectionJobsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? listPiiEntitiesDetectionJobsResponse_piiEntitiesDetectionJobPropertiesList Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& listPiiEntitiesDetectionJobs_nextToken Lens..~ rs Lens.^? listPiiEntitiesDetectionJobsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest ListPiiEntitiesDetectionJobs where type AWSResponse ListPiiEntitiesDetectionJobs = ListPiiEntitiesDetectionJobsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListPiiEntitiesDetectionJobsResponse' Prelude.<$> (x Data..?> "NextToken") Prelude.<*> ( x Data..?> "PiiEntitiesDetectionJobPropertiesList" Core..!@ Prelude.mempty ) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListPiiEntitiesDetectionJobs where hashWithSalt _salt ListPiiEntitiesDetectionJobs' {..} = _salt `Prelude.hashWithSalt` filter' `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken instance Prelude.NFData ListPiiEntitiesDetectionJobs where rnf ListPiiEntitiesDetectionJobs' {..} = Prelude.rnf filter' `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken instance Data.ToHeaders ListPiiEntitiesDetectionJobs where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "Comprehend_20171127.ListPiiEntitiesDetectionJobs" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListPiiEntitiesDetectionJobs where toJSON ListPiiEntitiesDetectionJobs' {..} = Data.object ( Prelude.catMaybes [ ("Filter" Data..=) Prelude.<$> filter', ("MaxResults" Data..=) Prelude.<$> maxResults, ("NextToken" Data..=) Prelude.<$> nextToken ] ) instance Data.ToPath ListPiiEntitiesDetectionJobs where toPath = Prelude.const "/" instance Data.ToQuery ListPiiEntitiesDetectionJobs where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newListPiiEntitiesDetectionJobsResponse' smart constructor. data ListPiiEntitiesDetectionJobsResponse = ListPiiEntitiesDetectionJobsResponse' { -- | Identifies the next page of results to return. nextToken :: Prelude.Maybe Prelude.Text, -- | A list containing the properties of each job that is returned. piiEntitiesDetectionJobPropertiesList :: Prelude.Maybe [PiiEntitiesDetectionJobProperties], -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListPiiEntitiesDetectionJobsResponse' 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: -- -- 'nextToken', 'listPiiEntitiesDetectionJobsResponse_nextToken' - Identifies the next page of results to return. -- -- 'piiEntitiesDetectionJobPropertiesList', 'listPiiEntitiesDetectionJobsResponse_piiEntitiesDetectionJobPropertiesList' - A list containing the properties of each job that is returned. -- -- 'httpStatus', 'listPiiEntitiesDetectionJobsResponse_httpStatus' - The response's http status code. newListPiiEntitiesDetectionJobsResponse :: -- | 'httpStatus' Prelude.Int -> ListPiiEntitiesDetectionJobsResponse newListPiiEntitiesDetectionJobsResponse pHttpStatus_ = ListPiiEntitiesDetectionJobsResponse' { nextToken = Prelude.Nothing, piiEntitiesDetectionJobPropertiesList = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Identifies the next page of results to return. listPiiEntitiesDetectionJobsResponse_nextToken :: Lens.Lens' ListPiiEntitiesDetectionJobsResponse (Prelude.Maybe Prelude.Text) listPiiEntitiesDetectionJobsResponse_nextToken = Lens.lens (\ListPiiEntitiesDetectionJobsResponse' {nextToken} -> nextToken) (\s@ListPiiEntitiesDetectionJobsResponse' {} a -> s {nextToken = a} :: ListPiiEntitiesDetectionJobsResponse) -- | A list containing the properties of each job that is returned. listPiiEntitiesDetectionJobsResponse_piiEntitiesDetectionJobPropertiesList :: Lens.Lens' ListPiiEntitiesDetectionJobsResponse (Prelude.Maybe [PiiEntitiesDetectionJobProperties]) listPiiEntitiesDetectionJobsResponse_piiEntitiesDetectionJobPropertiesList = Lens.lens (\ListPiiEntitiesDetectionJobsResponse' {piiEntitiesDetectionJobPropertiesList} -> piiEntitiesDetectionJobPropertiesList) (\s@ListPiiEntitiesDetectionJobsResponse' {} a -> s {piiEntitiesDetectionJobPropertiesList = a} :: ListPiiEntitiesDetectionJobsResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. listPiiEntitiesDetectionJobsResponse_httpStatus :: Lens.Lens' ListPiiEntitiesDetectionJobsResponse Prelude.Int listPiiEntitiesDetectionJobsResponse_httpStatus = Lens.lens (\ListPiiEntitiesDetectionJobsResponse' {httpStatus} -> httpStatus) (\s@ListPiiEntitiesDetectionJobsResponse' {} a -> s {httpStatus = a} :: ListPiiEntitiesDetectionJobsResponse) instance Prelude.NFData ListPiiEntitiesDetectionJobsResponse where rnf ListPiiEntitiesDetectionJobsResponse' {..} = Prelude.rnf nextToken `Prelude.seq` Prelude.rnf piiEntitiesDetectionJobPropertiesList `Prelude.seq` Prelude.rnf httpStatus