{-# 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.SageMaker.ListLabelingJobs -- 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 labeling jobs. -- -- This operation returns paginated results. module Amazonka.SageMaker.ListLabelingJobs ( -- * Creating a Request ListLabelingJobs (..), newListLabelingJobs, -- * Request Lenses listLabelingJobs_creationTimeAfter, listLabelingJobs_creationTimeBefore, listLabelingJobs_lastModifiedTimeAfter, listLabelingJobs_lastModifiedTimeBefore, listLabelingJobs_maxResults, listLabelingJobs_nameContains, listLabelingJobs_nextToken, listLabelingJobs_sortBy, listLabelingJobs_sortOrder, listLabelingJobs_statusEquals, -- * Destructuring the Response ListLabelingJobsResponse (..), newListLabelingJobsResponse, -- * Response Lenses listLabelingJobsResponse_labelingJobSummaryList, listLabelingJobsResponse_nextToken, listLabelingJobsResponse_httpStatus, ) where 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 import Amazonka.SageMaker.Types -- | /See:/ 'newListLabelingJobs' smart constructor. data ListLabelingJobs = ListLabelingJobs' { -- | A filter that returns only labeling jobs created after the specified -- time (timestamp). creationTimeAfter :: Prelude.Maybe Data.POSIX, -- | A filter that returns only labeling jobs created before the specified -- time (timestamp). creationTimeBefore :: Prelude.Maybe Data.POSIX, -- | A filter that returns only labeling jobs modified after the specified -- time (timestamp). lastModifiedTimeAfter :: Prelude.Maybe Data.POSIX, -- | A filter that returns only labeling jobs modified before the specified -- time (timestamp). lastModifiedTimeBefore :: Prelude.Maybe Data.POSIX, -- | The maximum number of labeling jobs to return in each page of the -- response. maxResults :: Prelude.Maybe Prelude.Natural, -- | A string in the labeling job name. This filter returns only labeling -- jobs whose name contains the specified string. nameContains :: Prelude.Maybe Prelude.Text, -- | If the result of the previous @ListLabelingJobs@ request was truncated, -- the response includes a @NextToken@. To retrieve the next set of -- labeling jobs, use the token in the next request. nextToken :: Prelude.Maybe Prelude.Text, -- | The field to sort results by. The default is @CreationTime@. sortBy :: Prelude.Maybe SortBy, -- | The sort order for results. The default is @Ascending@. sortOrder :: Prelude.Maybe SortOrder, -- | A filter that retrieves only labeling jobs with a specific status. statusEquals :: Prelude.Maybe LabelingJobStatus } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListLabelingJobs' 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: -- -- 'creationTimeAfter', 'listLabelingJobs_creationTimeAfter' - A filter that returns only labeling jobs created after the specified -- time (timestamp). -- -- 'creationTimeBefore', 'listLabelingJobs_creationTimeBefore' - A filter that returns only labeling jobs created before the specified -- time (timestamp). -- -- 'lastModifiedTimeAfter', 'listLabelingJobs_lastModifiedTimeAfter' - A filter that returns only labeling jobs modified after the specified -- time (timestamp). -- -- 'lastModifiedTimeBefore', 'listLabelingJobs_lastModifiedTimeBefore' - A filter that returns only labeling jobs modified before the specified -- time (timestamp). -- -- 'maxResults', 'listLabelingJobs_maxResults' - The maximum number of labeling jobs to return in each page of the -- response. -- -- 'nameContains', 'listLabelingJobs_nameContains' - A string in the labeling job name. This filter returns only labeling -- jobs whose name contains the specified string. -- -- 'nextToken', 'listLabelingJobs_nextToken' - If the result of the previous @ListLabelingJobs@ request was truncated, -- the response includes a @NextToken@. To retrieve the next set of -- labeling jobs, use the token in the next request. -- -- 'sortBy', 'listLabelingJobs_sortBy' - The field to sort results by. The default is @CreationTime@. -- -- 'sortOrder', 'listLabelingJobs_sortOrder' - The sort order for results. The default is @Ascending@. -- -- 'statusEquals', 'listLabelingJobs_statusEquals' - A filter that retrieves only labeling jobs with a specific status. newListLabelingJobs :: ListLabelingJobs newListLabelingJobs = ListLabelingJobs' { creationTimeAfter = Prelude.Nothing, creationTimeBefore = Prelude.Nothing, lastModifiedTimeAfter = Prelude.Nothing, lastModifiedTimeBefore = Prelude.Nothing, maxResults = Prelude.Nothing, nameContains = Prelude.Nothing, nextToken = Prelude.Nothing, sortBy = Prelude.Nothing, sortOrder = Prelude.Nothing, statusEquals = Prelude.Nothing } -- | A filter that returns only labeling jobs created after the specified -- time (timestamp). listLabelingJobs_creationTimeAfter :: Lens.Lens' ListLabelingJobs (Prelude.Maybe Prelude.UTCTime) listLabelingJobs_creationTimeAfter = Lens.lens (\ListLabelingJobs' {creationTimeAfter} -> creationTimeAfter) (\s@ListLabelingJobs' {} a -> s {creationTimeAfter = a} :: ListLabelingJobs) Prelude.. Lens.mapping Data._Time -- | A filter that returns only labeling jobs created before the specified -- time (timestamp). listLabelingJobs_creationTimeBefore :: Lens.Lens' ListLabelingJobs (Prelude.Maybe Prelude.UTCTime) listLabelingJobs_creationTimeBefore = Lens.lens (\ListLabelingJobs' {creationTimeBefore} -> creationTimeBefore) (\s@ListLabelingJobs' {} a -> s {creationTimeBefore = a} :: ListLabelingJobs) Prelude.. Lens.mapping Data._Time -- | A filter that returns only labeling jobs modified after the specified -- time (timestamp). listLabelingJobs_lastModifiedTimeAfter :: Lens.Lens' ListLabelingJobs (Prelude.Maybe Prelude.UTCTime) listLabelingJobs_lastModifiedTimeAfter = Lens.lens (\ListLabelingJobs' {lastModifiedTimeAfter} -> lastModifiedTimeAfter) (\s@ListLabelingJobs' {} a -> s {lastModifiedTimeAfter = a} :: ListLabelingJobs) Prelude.. Lens.mapping Data._Time -- | A filter that returns only labeling jobs modified before the specified -- time (timestamp). listLabelingJobs_lastModifiedTimeBefore :: Lens.Lens' ListLabelingJobs (Prelude.Maybe Prelude.UTCTime) listLabelingJobs_lastModifiedTimeBefore = Lens.lens (\ListLabelingJobs' {lastModifiedTimeBefore} -> lastModifiedTimeBefore) (\s@ListLabelingJobs' {} a -> s {lastModifiedTimeBefore = a} :: ListLabelingJobs) Prelude.. Lens.mapping Data._Time -- | The maximum number of labeling jobs to return in each page of the -- response. listLabelingJobs_maxResults :: Lens.Lens' ListLabelingJobs (Prelude.Maybe Prelude.Natural) listLabelingJobs_maxResults = Lens.lens (\ListLabelingJobs' {maxResults} -> maxResults) (\s@ListLabelingJobs' {} a -> s {maxResults = a} :: ListLabelingJobs) -- | A string in the labeling job name. This filter returns only labeling -- jobs whose name contains the specified string. listLabelingJobs_nameContains :: Lens.Lens' ListLabelingJobs (Prelude.Maybe Prelude.Text) listLabelingJobs_nameContains = Lens.lens (\ListLabelingJobs' {nameContains} -> nameContains) (\s@ListLabelingJobs' {} a -> s {nameContains = a} :: ListLabelingJobs) -- | If the result of the previous @ListLabelingJobs@ request was truncated, -- the response includes a @NextToken@. To retrieve the next set of -- labeling jobs, use the token in the next request. listLabelingJobs_nextToken :: Lens.Lens' ListLabelingJobs (Prelude.Maybe Prelude.Text) listLabelingJobs_nextToken = Lens.lens (\ListLabelingJobs' {nextToken} -> nextToken) (\s@ListLabelingJobs' {} a -> s {nextToken = a} :: ListLabelingJobs) -- | The field to sort results by. The default is @CreationTime@. listLabelingJobs_sortBy :: Lens.Lens' ListLabelingJobs (Prelude.Maybe SortBy) listLabelingJobs_sortBy = Lens.lens (\ListLabelingJobs' {sortBy} -> sortBy) (\s@ListLabelingJobs' {} a -> s {sortBy = a} :: ListLabelingJobs) -- | The sort order for results. The default is @Ascending@. listLabelingJobs_sortOrder :: Lens.Lens' ListLabelingJobs (Prelude.Maybe SortOrder) listLabelingJobs_sortOrder = Lens.lens (\ListLabelingJobs' {sortOrder} -> sortOrder) (\s@ListLabelingJobs' {} a -> s {sortOrder = a} :: ListLabelingJobs) -- | A filter that retrieves only labeling jobs with a specific status. listLabelingJobs_statusEquals :: Lens.Lens' ListLabelingJobs (Prelude.Maybe LabelingJobStatus) listLabelingJobs_statusEquals = Lens.lens (\ListLabelingJobs' {statusEquals} -> statusEquals) (\s@ListLabelingJobs' {} a -> s {statusEquals = a} :: ListLabelingJobs) instance Core.AWSPager ListLabelingJobs where page rq rs | Core.stop ( rs Lens.^? listLabelingJobsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? listLabelingJobsResponse_labelingJobSummaryList Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& listLabelingJobs_nextToken Lens..~ rs Lens.^? listLabelingJobsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest ListLabelingJobs where type AWSResponse ListLabelingJobs = ListLabelingJobsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListLabelingJobsResponse' Prelude.<$> ( x Data..?> "LabelingJobSummaryList" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "NextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListLabelingJobs where hashWithSalt _salt ListLabelingJobs' {..} = _salt `Prelude.hashWithSalt` creationTimeAfter `Prelude.hashWithSalt` creationTimeBefore `Prelude.hashWithSalt` lastModifiedTimeAfter `Prelude.hashWithSalt` lastModifiedTimeBefore `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nameContains `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` sortBy `Prelude.hashWithSalt` sortOrder `Prelude.hashWithSalt` statusEquals instance Prelude.NFData ListLabelingJobs where rnf ListLabelingJobs' {..} = Prelude.rnf creationTimeAfter `Prelude.seq` Prelude.rnf creationTimeBefore `Prelude.seq` Prelude.rnf lastModifiedTimeAfter `Prelude.seq` Prelude.rnf lastModifiedTimeBefore `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nameContains `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf sortBy `Prelude.seq` Prelude.rnf sortOrder `Prelude.seq` Prelude.rnf statusEquals instance Data.ToHeaders ListLabelingJobs where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ("SageMaker.ListLabelingJobs" :: Prelude.ByteString), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListLabelingJobs where toJSON ListLabelingJobs' {..} = Data.object ( Prelude.catMaybes [ ("CreationTimeAfter" Data..=) Prelude.<$> creationTimeAfter, ("CreationTimeBefore" Data..=) Prelude.<$> creationTimeBefore, ("LastModifiedTimeAfter" Data..=) Prelude.<$> lastModifiedTimeAfter, ("LastModifiedTimeBefore" Data..=) Prelude.<$> lastModifiedTimeBefore, ("MaxResults" Data..=) Prelude.<$> maxResults, ("NameContains" Data..=) Prelude.<$> nameContains, ("NextToken" Data..=) Prelude.<$> nextToken, ("SortBy" Data..=) Prelude.<$> sortBy, ("SortOrder" Data..=) Prelude.<$> sortOrder, ("StatusEquals" Data..=) Prelude.<$> statusEquals ] ) instance Data.ToPath ListLabelingJobs where toPath = Prelude.const "/" instance Data.ToQuery ListLabelingJobs where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newListLabelingJobsResponse' smart constructor. data ListLabelingJobsResponse = ListLabelingJobsResponse' { -- | An array of @LabelingJobSummary@ objects, each describing a labeling -- job. labelingJobSummaryList :: Prelude.Maybe [LabelingJobSummary], -- | If the response is truncated, SageMaker returns this token. To retrieve -- the next set of labeling jobs, use it in the subsequent 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 'ListLabelingJobsResponse' 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: -- -- 'labelingJobSummaryList', 'listLabelingJobsResponse_labelingJobSummaryList' - An array of @LabelingJobSummary@ objects, each describing a labeling -- job. -- -- 'nextToken', 'listLabelingJobsResponse_nextToken' - If the response is truncated, SageMaker returns this token. To retrieve -- the next set of labeling jobs, use it in the subsequent request. -- -- 'httpStatus', 'listLabelingJobsResponse_httpStatus' - The response's http status code. newListLabelingJobsResponse :: -- | 'httpStatus' Prelude.Int -> ListLabelingJobsResponse newListLabelingJobsResponse pHttpStatus_ = ListLabelingJobsResponse' { labelingJobSummaryList = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | An array of @LabelingJobSummary@ objects, each describing a labeling -- job. listLabelingJobsResponse_labelingJobSummaryList :: Lens.Lens' ListLabelingJobsResponse (Prelude.Maybe [LabelingJobSummary]) listLabelingJobsResponse_labelingJobSummaryList = Lens.lens (\ListLabelingJobsResponse' {labelingJobSummaryList} -> labelingJobSummaryList) (\s@ListLabelingJobsResponse' {} a -> s {labelingJobSummaryList = a} :: ListLabelingJobsResponse) Prelude.. Lens.mapping Lens.coerced -- | If the response is truncated, SageMaker returns this token. To retrieve -- the next set of labeling jobs, use it in the subsequent request. listLabelingJobsResponse_nextToken :: Lens.Lens' ListLabelingJobsResponse (Prelude.Maybe Prelude.Text) listLabelingJobsResponse_nextToken = Lens.lens (\ListLabelingJobsResponse' {nextToken} -> nextToken) (\s@ListLabelingJobsResponse' {} a -> s {nextToken = a} :: ListLabelingJobsResponse) -- | The response's http status code. listLabelingJobsResponse_httpStatus :: Lens.Lens' ListLabelingJobsResponse Prelude.Int listLabelingJobsResponse_httpStatus = Lens.lens (\ListLabelingJobsResponse' {httpStatus} -> httpStatus) (\s@ListLabelingJobsResponse' {} a -> s {httpStatus = a} :: ListLabelingJobsResponse) instance Prelude.NFData ListLabelingJobsResponse where rnf ListLabelingJobsResponse' {..} = Prelude.rnf labelingJobSummaryList `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus