{-# 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.ListCompilationJobs -- 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 model compilation jobs that satisfy various filters. -- -- To create a model compilation job, use CreateCompilationJob. To get -- information about a particular model compilation job you have created, -- use DescribeCompilationJob. -- -- This operation returns paginated results. module Amazonka.SageMaker.ListCompilationJobs ( -- * Creating a Request ListCompilationJobs (..), newListCompilationJobs, -- * Request Lenses listCompilationJobs_creationTimeAfter, listCompilationJobs_creationTimeBefore, listCompilationJobs_lastModifiedTimeAfter, listCompilationJobs_lastModifiedTimeBefore, listCompilationJobs_maxResults, listCompilationJobs_nameContains, listCompilationJobs_nextToken, listCompilationJobs_sortBy, listCompilationJobs_sortOrder, listCompilationJobs_statusEquals, -- * Destructuring the Response ListCompilationJobsResponse (..), newListCompilationJobsResponse, -- * Response Lenses listCompilationJobsResponse_nextToken, listCompilationJobsResponse_httpStatus, listCompilationJobsResponse_compilationJobSummaries, ) 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:/ 'newListCompilationJobs' smart constructor. data ListCompilationJobs = ListCompilationJobs' { -- | A filter that returns the model compilation jobs that were created after -- a specified time. creationTimeAfter :: Prelude.Maybe Data.POSIX, -- | A filter that returns the model compilation jobs that were created -- before a specified time. creationTimeBefore :: Prelude.Maybe Data.POSIX, -- | A filter that returns the model compilation jobs that were modified -- after a specified time. lastModifiedTimeAfter :: Prelude.Maybe Data.POSIX, -- | A filter that returns the model compilation jobs that were modified -- before a specified time. lastModifiedTimeBefore :: Prelude.Maybe Data.POSIX, -- | The maximum number of model compilation jobs to return in the response. maxResults :: Prelude.Maybe Prelude.Natural, -- | A filter that returns the model compilation jobs whose name contains a -- specified string. nameContains :: Prelude.Maybe Prelude.Text, -- | If the result of the previous @ListCompilationJobs@ request was -- truncated, the response includes a @NextToken@. To retrieve the next set -- of model compilation jobs, use the token in the next request. nextToken :: Prelude.Maybe Prelude.Text, -- | The field by which to sort results. The default is @CreationTime@. sortBy :: Prelude.Maybe ListCompilationJobsSortBy, -- | The sort order for results. The default is @Ascending@. sortOrder :: Prelude.Maybe SortOrder, -- | A filter that retrieves model compilation jobs with a specific -- DescribeCompilationJobResponse$CompilationJobStatus status. statusEquals :: Prelude.Maybe CompilationJobStatus } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListCompilationJobs' 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', 'listCompilationJobs_creationTimeAfter' - A filter that returns the model compilation jobs that were created after -- a specified time. -- -- 'creationTimeBefore', 'listCompilationJobs_creationTimeBefore' - A filter that returns the model compilation jobs that were created -- before a specified time. -- -- 'lastModifiedTimeAfter', 'listCompilationJobs_lastModifiedTimeAfter' - A filter that returns the model compilation jobs that were modified -- after a specified time. -- -- 'lastModifiedTimeBefore', 'listCompilationJobs_lastModifiedTimeBefore' - A filter that returns the model compilation jobs that were modified -- before a specified time. -- -- 'maxResults', 'listCompilationJobs_maxResults' - The maximum number of model compilation jobs to return in the response. -- -- 'nameContains', 'listCompilationJobs_nameContains' - A filter that returns the model compilation jobs whose name contains a -- specified string. -- -- 'nextToken', 'listCompilationJobs_nextToken' - If the result of the previous @ListCompilationJobs@ request was -- truncated, the response includes a @NextToken@. To retrieve the next set -- of model compilation jobs, use the token in the next request. -- -- 'sortBy', 'listCompilationJobs_sortBy' - The field by which to sort results. The default is @CreationTime@. -- -- 'sortOrder', 'listCompilationJobs_sortOrder' - The sort order for results. The default is @Ascending@. -- -- 'statusEquals', 'listCompilationJobs_statusEquals' - A filter that retrieves model compilation jobs with a specific -- DescribeCompilationJobResponse$CompilationJobStatus status. newListCompilationJobs :: ListCompilationJobs newListCompilationJobs = ListCompilationJobs' { 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 the model compilation jobs that were created after -- a specified time. listCompilationJobs_creationTimeAfter :: Lens.Lens' ListCompilationJobs (Prelude.Maybe Prelude.UTCTime) listCompilationJobs_creationTimeAfter = Lens.lens (\ListCompilationJobs' {creationTimeAfter} -> creationTimeAfter) (\s@ListCompilationJobs' {} a -> s {creationTimeAfter = a} :: ListCompilationJobs) Prelude.. Lens.mapping Data._Time -- | A filter that returns the model compilation jobs that were created -- before a specified time. listCompilationJobs_creationTimeBefore :: Lens.Lens' ListCompilationJobs (Prelude.Maybe Prelude.UTCTime) listCompilationJobs_creationTimeBefore = Lens.lens (\ListCompilationJobs' {creationTimeBefore} -> creationTimeBefore) (\s@ListCompilationJobs' {} a -> s {creationTimeBefore = a} :: ListCompilationJobs) Prelude.. Lens.mapping Data._Time -- | A filter that returns the model compilation jobs that were modified -- after a specified time. listCompilationJobs_lastModifiedTimeAfter :: Lens.Lens' ListCompilationJobs (Prelude.Maybe Prelude.UTCTime) listCompilationJobs_lastModifiedTimeAfter = Lens.lens (\ListCompilationJobs' {lastModifiedTimeAfter} -> lastModifiedTimeAfter) (\s@ListCompilationJobs' {} a -> s {lastModifiedTimeAfter = a} :: ListCompilationJobs) Prelude.. Lens.mapping Data._Time -- | A filter that returns the model compilation jobs that were modified -- before a specified time. listCompilationJobs_lastModifiedTimeBefore :: Lens.Lens' ListCompilationJobs (Prelude.Maybe Prelude.UTCTime) listCompilationJobs_lastModifiedTimeBefore = Lens.lens (\ListCompilationJobs' {lastModifiedTimeBefore} -> lastModifiedTimeBefore) (\s@ListCompilationJobs' {} a -> s {lastModifiedTimeBefore = a} :: ListCompilationJobs) Prelude.. Lens.mapping Data._Time -- | The maximum number of model compilation jobs to return in the response. listCompilationJobs_maxResults :: Lens.Lens' ListCompilationJobs (Prelude.Maybe Prelude.Natural) listCompilationJobs_maxResults = Lens.lens (\ListCompilationJobs' {maxResults} -> maxResults) (\s@ListCompilationJobs' {} a -> s {maxResults = a} :: ListCompilationJobs) -- | A filter that returns the model compilation jobs whose name contains a -- specified string. listCompilationJobs_nameContains :: Lens.Lens' ListCompilationJobs (Prelude.Maybe Prelude.Text) listCompilationJobs_nameContains = Lens.lens (\ListCompilationJobs' {nameContains} -> nameContains) (\s@ListCompilationJobs' {} a -> s {nameContains = a} :: ListCompilationJobs) -- | If the result of the previous @ListCompilationJobs@ request was -- truncated, the response includes a @NextToken@. To retrieve the next set -- of model compilation jobs, use the token in the next request. listCompilationJobs_nextToken :: Lens.Lens' ListCompilationJobs (Prelude.Maybe Prelude.Text) listCompilationJobs_nextToken = Lens.lens (\ListCompilationJobs' {nextToken} -> nextToken) (\s@ListCompilationJobs' {} a -> s {nextToken = a} :: ListCompilationJobs) -- | The field by which to sort results. The default is @CreationTime@. listCompilationJobs_sortBy :: Lens.Lens' ListCompilationJobs (Prelude.Maybe ListCompilationJobsSortBy) listCompilationJobs_sortBy = Lens.lens (\ListCompilationJobs' {sortBy} -> sortBy) (\s@ListCompilationJobs' {} a -> s {sortBy = a} :: ListCompilationJobs) -- | The sort order for results. The default is @Ascending@. listCompilationJobs_sortOrder :: Lens.Lens' ListCompilationJobs (Prelude.Maybe SortOrder) listCompilationJobs_sortOrder = Lens.lens (\ListCompilationJobs' {sortOrder} -> sortOrder) (\s@ListCompilationJobs' {} a -> s {sortOrder = a} :: ListCompilationJobs) -- | A filter that retrieves model compilation jobs with a specific -- DescribeCompilationJobResponse$CompilationJobStatus status. listCompilationJobs_statusEquals :: Lens.Lens' ListCompilationJobs (Prelude.Maybe CompilationJobStatus) listCompilationJobs_statusEquals = Lens.lens (\ListCompilationJobs' {statusEquals} -> statusEquals) (\s@ListCompilationJobs' {} a -> s {statusEquals = a} :: ListCompilationJobs) instance Core.AWSPager ListCompilationJobs where page rq rs | Core.stop ( rs Lens.^? listCompilationJobsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^. listCompilationJobsResponse_compilationJobSummaries ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& listCompilationJobs_nextToken Lens..~ rs Lens.^? listCompilationJobsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest ListCompilationJobs where type AWSResponse ListCompilationJobs = ListCompilationJobsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListCompilationJobsResponse' Prelude.<$> (x Data..?> "NextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) Prelude.<*> ( x Data..?> "CompilationJobSummaries" Core..!@ Prelude.mempty ) ) instance Prelude.Hashable ListCompilationJobs where hashWithSalt _salt ListCompilationJobs' {..} = _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 ListCompilationJobs where rnf ListCompilationJobs' {..} = 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 ListCompilationJobs where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "SageMaker.ListCompilationJobs" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListCompilationJobs where toJSON ListCompilationJobs' {..} = 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 ListCompilationJobs where toPath = Prelude.const "/" instance Data.ToQuery ListCompilationJobs where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newListCompilationJobsResponse' smart constructor. data ListCompilationJobsResponse = ListCompilationJobsResponse' { -- | If the response is truncated, Amazon SageMaker returns this @NextToken@. -- To retrieve the next set of model compilation jobs, use this token in -- the next request. nextToken :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int, -- | An array of CompilationJobSummary objects, each describing a model -- compilation job. compilationJobSummaries :: [CompilationJobSummary] } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListCompilationJobsResponse' 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', 'listCompilationJobsResponse_nextToken' - If the response is truncated, Amazon SageMaker returns this @NextToken@. -- To retrieve the next set of model compilation jobs, use this token in -- the next request. -- -- 'httpStatus', 'listCompilationJobsResponse_httpStatus' - The response's http status code. -- -- 'compilationJobSummaries', 'listCompilationJobsResponse_compilationJobSummaries' - An array of CompilationJobSummary objects, each describing a model -- compilation job. newListCompilationJobsResponse :: -- | 'httpStatus' Prelude.Int -> ListCompilationJobsResponse newListCompilationJobsResponse pHttpStatus_ = ListCompilationJobsResponse' { nextToken = Prelude.Nothing, httpStatus = pHttpStatus_, compilationJobSummaries = Prelude.mempty } -- | If the response is truncated, Amazon SageMaker returns this @NextToken@. -- To retrieve the next set of model compilation jobs, use this token in -- the next request. listCompilationJobsResponse_nextToken :: Lens.Lens' ListCompilationJobsResponse (Prelude.Maybe Prelude.Text) listCompilationJobsResponse_nextToken = Lens.lens (\ListCompilationJobsResponse' {nextToken} -> nextToken) (\s@ListCompilationJobsResponse' {} a -> s {nextToken = a} :: ListCompilationJobsResponse) -- | The response's http status code. listCompilationJobsResponse_httpStatus :: Lens.Lens' ListCompilationJobsResponse Prelude.Int listCompilationJobsResponse_httpStatus = Lens.lens (\ListCompilationJobsResponse' {httpStatus} -> httpStatus) (\s@ListCompilationJobsResponse' {} a -> s {httpStatus = a} :: ListCompilationJobsResponse) -- | An array of CompilationJobSummary objects, each describing a model -- compilation job. listCompilationJobsResponse_compilationJobSummaries :: Lens.Lens' ListCompilationJobsResponse [CompilationJobSummary] listCompilationJobsResponse_compilationJobSummaries = Lens.lens (\ListCompilationJobsResponse' {compilationJobSummaries} -> compilationJobSummaries) (\s@ListCompilationJobsResponse' {} a -> s {compilationJobSummaries = a} :: ListCompilationJobsResponse) Prelude.. Lens.coerced instance Prelude.NFData ListCompilationJobsResponse where rnf ListCompilationJobsResponse' {..} = Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus `Prelude.seq` Prelude.rnf compilationJobSummaries