{-# 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.ListProjects -- 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 projects in an Amazon Web Services account. module Amazonka.SageMaker.ListProjects ( -- * Creating a Request ListProjects (..), newListProjects, -- * Request Lenses listProjects_creationTimeAfter, listProjects_creationTimeBefore, listProjects_maxResults, listProjects_nameContains, listProjects_nextToken, listProjects_sortBy, listProjects_sortOrder, -- * Destructuring the Response ListProjectsResponse (..), newListProjectsResponse, -- * Response Lenses listProjectsResponse_nextToken, listProjectsResponse_httpStatus, listProjectsResponse_projectSummaryList, ) 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:/ 'newListProjects' smart constructor. data ListProjects = ListProjects' { -- | A filter that returns the projects that were created after a specified -- time. creationTimeAfter :: Prelude.Maybe Data.POSIX, -- | A filter that returns the projects that were created before a specified -- time. creationTimeBefore :: Prelude.Maybe Data.POSIX, -- | The maximum number of projects to return in the response. maxResults :: Prelude.Maybe Prelude.Natural, -- | A filter that returns the projects whose name contains a specified -- string. nameContains :: Prelude.Maybe Prelude.Text, -- | If the result of the previous @ListProjects@ request was truncated, the -- response includes a @NextToken@. To retrieve the next set of projects, -- 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 ProjectSortBy, -- | The sort order for results. The default is @Ascending@. sortOrder :: Prelude.Maybe ProjectSortOrder } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListProjects' 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', 'listProjects_creationTimeAfter' - A filter that returns the projects that were created after a specified -- time. -- -- 'creationTimeBefore', 'listProjects_creationTimeBefore' - A filter that returns the projects that were created before a specified -- time. -- -- 'maxResults', 'listProjects_maxResults' - The maximum number of projects to return in the response. -- -- 'nameContains', 'listProjects_nameContains' - A filter that returns the projects whose name contains a specified -- string. -- -- 'nextToken', 'listProjects_nextToken' - If the result of the previous @ListProjects@ request was truncated, the -- response includes a @NextToken@. To retrieve the next set of projects, -- use the token in the next request. -- -- 'sortBy', 'listProjects_sortBy' - The field by which to sort results. The default is @CreationTime@. -- -- 'sortOrder', 'listProjects_sortOrder' - The sort order for results. The default is @Ascending@. newListProjects :: ListProjects newListProjects = ListProjects' { creationTimeAfter = Prelude.Nothing, creationTimeBefore = Prelude.Nothing, maxResults = Prelude.Nothing, nameContains = Prelude.Nothing, nextToken = Prelude.Nothing, sortBy = Prelude.Nothing, sortOrder = Prelude.Nothing } -- | A filter that returns the projects that were created after a specified -- time. listProjects_creationTimeAfter :: Lens.Lens' ListProjects (Prelude.Maybe Prelude.UTCTime) listProjects_creationTimeAfter = Lens.lens (\ListProjects' {creationTimeAfter} -> creationTimeAfter) (\s@ListProjects' {} a -> s {creationTimeAfter = a} :: ListProjects) Prelude.. Lens.mapping Data._Time -- | A filter that returns the projects that were created before a specified -- time. listProjects_creationTimeBefore :: Lens.Lens' ListProjects (Prelude.Maybe Prelude.UTCTime) listProjects_creationTimeBefore = Lens.lens (\ListProjects' {creationTimeBefore} -> creationTimeBefore) (\s@ListProjects' {} a -> s {creationTimeBefore = a} :: ListProjects) Prelude.. Lens.mapping Data._Time -- | The maximum number of projects to return in the response. listProjects_maxResults :: Lens.Lens' ListProjects (Prelude.Maybe Prelude.Natural) listProjects_maxResults = Lens.lens (\ListProjects' {maxResults} -> maxResults) (\s@ListProjects' {} a -> s {maxResults = a} :: ListProjects) -- | A filter that returns the projects whose name contains a specified -- string. listProjects_nameContains :: Lens.Lens' ListProjects (Prelude.Maybe Prelude.Text) listProjects_nameContains = Lens.lens (\ListProjects' {nameContains} -> nameContains) (\s@ListProjects' {} a -> s {nameContains = a} :: ListProjects) -- | If the result of the previous @ListProjects@ request was truncated, the -- response includes a @NextToken@. To retrieve the next set of projects, -- use the token in the next request. listProjects_nextToken :: Lens.Lens' ListProjects (Prelude.Maybe Prelude.Text) listProjects_nextToken = Lens.lens (\ListProjects' {nextToken} -> nextToken) (\s@ListProjects' {} a -> s {nextToken = a} :: ListProjects) -- | The field by which to sort results. The default is @CreationTime@. listProjects_sortBy :: Lens.Lens' ListProjects (Prelude.Maybe ProjectSortBy) listProjects_sortBy = Lens.lens (\ListProjects' {sortBy} -> sortBy) (\s@ListProjects' {} a -> s {sortBy = a} :: ListProjects) -- | The sort order for results. The default is @Ascending@. listProjects_sortOrder :: Lens.Lens' ListProjects (Prelude.Maybe ProjectSortOrder) listProjects_sortOrder = Lens.lens (\ListProjects' {sortOrder} -> sortOrder) (\s@ListProjects' {} a -> s {sortOrder = a} :: ListProjects) instance Core.AWSRequest ListProjects where type AWSResponse ListProjects = ListProjectsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListProjectsResponse' Prelude.<$> (x Data..?> "NextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) Prelude.<*> ( x Data..?> "ProjectSummaryList" Core..!@ Prelude.mempty ) ) instance Prelude.Hashable ListProjects where hashWithSalt _salt ListProjects' {..} = _salt `Prelude.hashWithSalt` creationTimeAfter `Prelude.hashWithSalt` creationTimeBefore `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nameContains `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` sortBy `Prelude.hashWithSalt` sortOrder instance Prelude.NFData ListProjects where rnf ListProjects' {..} = Prelude.rnf creationTimeAfter `Prelude.seq` Prelude.rnf creationTimeBefore `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 instance Data.ToHeaders ListProjects where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ("SageMaker.ListProjects" :: Prelude.ByteString), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListProjects where toJSON ListProjects' {..} = Data.object ( Prelude.catMaybes [ ("CreationTimeAfter" Data..=) Prelude.<$> creationTimeAfter, ("CreationTimeBefore" Data..=) Prelude.<$> creationTimeBefore, ("MaxResults" Data..=) Prelude.<$> maxResults, ("NameContains" Data..=) Prelude.<$> nameContains, ("NextToken" Data..=) Prelude.<$> nextToken, ("SortBy" Data..=) Prelude.<$> sortBy, ("SortOrder" Data..=) Prelude.<$> sortOrder ] ) instance Data.ToPath ListProjects where toPath = Prelude.const "/" instance Data.ToQuery ListProjects where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newListProjectsResponse' smart constructor. data ListProjectsResponse = ListProjectsResponse' { -- | 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 response's http status code. httpStatus :: Prelude.Int, -- | A list of summaries of projects. projectSummaryList :: [ProjectSummary] } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListProjectsResponse' 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', 'listProjectsResponse_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. -- -- 'httpStatus', 'listProjectsResponse_httpStatus' - The response's http status code. -- -- 'projectSummaryList', 'listProjectsResponse_projectSummaryList' - A list of summaries of projects. newListProjectsResponse :: -- | 'httpStatus' Prelude.Int -> ListProjectsResponse newListProjectsResponse pHttpStatus_ = ListProjectsResponse' { nextToken = Prelude.Nothing, httpStatus = pHttpStatus_, projectSummaryList = Prelude.mempty } -- | 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. listProjectsResponse_nextToken :: Lens.Lens' ListProjectsResponse (Prelude.Maybe Prelude.Text) listProjectsResponse_nextToken = Lens.lens (\ListProjectsResponse' {nextToken} -> nextToken) (\s@ListProjectsResponse' {} a -> s {nextToken = a} :: ListProjectsResponse) -- | The response's http status code. listProjectsResponse_httpStatus :: Lens.Lens' ListProjectsResponse Prelude.Int listProjectsResponse_httpStatus = Lens.lens (\ListProjectsResponse' {httpStatus} -> httpStatus) (\s@ListProjectsResponse' {} a -> s {httpStatus = a} :: ListProjectsResponse) -- | A list of summaries of projects. listProjectsResponse_projectSummaryList :: Lens.Lens' ListProjectsResponse [ProjectSummary] listProjectsResponse_projectSummaryList = Lens.lens (\ListProjectsResponse' {projectSummaryList} -> projectSummaryList) (\s@ListProjectsResponse' {} a -> s {projectSummaryList = a} :: ListProjectsResponse) Prelude.. Lens.coerced instance Prelude.NFData ListProjectsResponse where rnf ListProjectsResponse' {..} = Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus `Prelude.seq` Prelude.rnf projectSummaryList