{-# 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.ListWorkteams -- 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 private work teams that you have defined in a region. The -- list may be empty if no work team satisfies the filter specified in the -- @NameContains@ parameter. -- -- This operation returns paginated results. module Amazonka.SageMaker.ListWorkteams ( -- * Creating a Request ListWorkteams (..), newListWorkteams, -- * Request Lenses listWorkteams_maxResults, listWorkteams_nameContains, listWorkteams_nextToken, listWorkteams_sortBy, listWorkteams_sortOrder, -- * Destructuring the Response ListWorkteamsResponse (..), newListWorkteamsResponse, -- * Response Lenses listWorkteamsResponse_nextToken, listWorkteamsResponse_httpStatus, listWorkteamsResponse_workteams, ) 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:/ 'newListWorkteams' smart constructor. data ListWorkteams = ListWorkteams' { -- | The maximum number of work teams to return in each page of the response. maxResults :: Prelude.Maybe Prelude.Natural, -- | A string in the work team\'s name. This filter returns only work teams -- whose name contains the specified string. nameContains :: Prelude.Maybe Prelude.Text, -- | If the result of the previous @ListWorkteams@ 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 ListWorkteamsSortByOptions, -- | The sort order for results. The default is @Ascending@. sortOrder :: Prelude.Maybe SortOrder } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListWorkteams' 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', 'listWorkteams_maxResults' - The maximum number of work teams to return in each page of the response. -- -- 'nameContains', 'listWorkteams_nameContains' - A string in the work team\'s name. This filter returns only work teams -- whose name contains the specified string. -- -- 'nextToken', 'listWorkteams_nextToken' - If the result of the previous @ListWorkteams@ request was truncated, the -- response includes a @NextToken@. To retrieve the next set of labeling -- jobs, use the token in the next request. -- -- 'sortBy', 'listWorkteams_sortBy' - The field to sort results by. The default is @CreationTime@. -- -- 'sortOrder', 'listWorkteams_sortOrder' - The sort order for results. The default is @Ascending@. newListWorkteams :: ListWorkteams newListWorkteams = ListWorkteams' { maxResults = Prelude.Nothing, nameContains = Prelude.Nothing, nextToken = Prelude.Nothing, sortBy = Prelude.Nothing, sortOrder = Prelude.Nothing } -- | The maximum number of work teams to return in each page of the response. listWorkteams_maxResults :: Lens.Lens' ListWorkteams (Prelude.Maybe Prelude.Natural) listWorkteams_maxResults = Lens.lens (\ListWorkteams' {maxResults} -> maxResults) (\s@ListWorkteams' {} a -> s {maxResults = a} :: ListWorkteams) -- | A string in the work team\'s name. This filter returns only work teams -- whose name contains the specified string. listWorkteams_nameContains :: Lens.Lens' ListWorkteams (Prelude.Maybe Prelude.Text) listWorkteams_nameContains = Lens.lens (\ListWorkteams' {nameContains} -> nameContains) (\s@ListWorkteams' {} a -> s {nameContains = a} :: ListWorkteams) -- | If the result of the previous @ListWorkteams@ request was truncated, the -- response includes a @NextToken@. To retrieve the next set of labeling -- jobs, use the token in the next request. listWorkteams_nextToken :: Lens.Lens' ListWorkteams (Prelude.Maybe Prelude.Text) listWorkteams_nextToken = Lens.lens (\ListWorkteams' {nextToken} -> nextToken) (\s@ListWorkteams' {} a -> s {nextToken = a} :: ListWorkteams) -- | The field to sort results by. The default is @CreationTime@. listWorkteams_sortBy :: Lens.Lens' ListWorkteams (Prelude.Maybe ListWorkteamsSortByOptions) listWorkteams_sortBy = Lens.lens (\ListWorkteams' {sortBy} -> sortBy) (\s@ListWorkteams' {} a -> s {sortBy = a} :: ListWorkteams) -- | The sort order for results. The default is @Ascending@. listWorkteams_sortOrder :: Lens.Lens' ListWorkteams (Prelude.Maybe SortOrder) listWorkteams_sortOrder = Lens.lens (\ListWorkteams' {sortOrder} -> sortOrder) (\s@ListWorkteams' {} a -> s {sortOrder = a} :: ListWorkteams) instance Core.AWSPager ListWorkteams where page rq rs | Core.stop ( rs Lens.^? listWorkteamsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop (rs Lens.^. listWorkteamsResponse_workteams) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& listWorkteams_nextToken Lens..~ rs Lens.^? listWorkteamsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest ListWorkteams where type AWSResponse ListWorkteams = ListWorkteamsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListWorkteamsResponse' Prelude.<$> (x Data..?> "NextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) Prelude.<*> (x Data..?> "Workteams" Core..!@ Prelude.mempty) ) instance Prelude.Hashable ListWorkteams where hashWithSalt _salt ListWorkteams' {..} = _salt `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nameContains `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` sortBy `Prelude.hashWithSalt` sortOrder instance Prelude.NFData ListWorkteams where rnf ListWorkteams' {..} = 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 ListWorkteams where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ("SageMaker.ListWorkteams" :: Prelude.ByteString), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListWorkteams where toJSON ListWorkteams' {..} = Data.object ( Prelude.catMaybes [ ("MaxResults" Data..=) Prelude.<$> maxResults, ("NameContains" Data..=) Prelude.<$> nameContains, ("NextToken" Data..=) Prelude.<$> nextToken, ("SortBy" Data..=) Prelude.<$> sortBy, ("SortOrder" Data..=) Prelude.<$> sortOrder ] ) instance Data.ToPath ListWorkteams where toPath = Prelude.const "/" instance Data.ToQuery ListWorkteams where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newListWorkteamsResponse' smart constructor. data ListWorkteamsResponse = ListWorkteamsResponse' { -- | If the response is truncated, Amazon SageMaker returns this token. To -- retrieve the next set of work teams, use it in the subsequent request. nextToken :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int, -- | An array of @Workteam@ objects, each describing a work team. workteams :: [Workteam] } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListWorkteamsResponse' 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', 'listWorkteamsResponse_nextToken' - If the response is truncated, Amazon SageMaker returns this token. To -- retrieve the next set of work teams, use it in the subsequent request. -- -- 'httpStatus', 'listWorkteamsResponse_httpStatus' - The response's http status code. -- -- 'workteams', 'listWorkteamsResponse_workteams' - An array of @Workteam@ objects, each describing a work team. newListWorkteamsResponse :: -- | 'httpStatus' Prelude.Int -> ListWorkteamsResponse newListWorkteamsResponse pHttpStatus_ = ListWorkteamsResponse' { nextToken = Prelude.Nothing, httpStatus = pHttpStatus_, workteams = Prelude.mempty } -- | If the response is truncated, Amazon SageMaker returns this token. To -- retrieve the next set of work teams, use it in the subsequent request. listWorkteamsResponse_nextToken :: Lens.Lens' ListWorkteamsResponse (Prelude.Maybe Prelude.Text) listWorkteamsResponse_nextToken = Lens.lens (\ListWorkteamsResponse' {nextToken} -> nextToken) (\s@ListWorkteamsResponse' {} a -> s {nextToken = a} :: ListWorkteamsResponse) -- | The response's http status code. listWorkteamsResponse_httpStatus :: Lens.Lens' ListWorkteamsResponse Prelude.Int listWorkteamsResponse_httpStatus = Lens.lens (\ListWorkteamsResponse' {httpStatus} -> httpStatus) (\s@ListWorkteamsResponse' {} a -> s {httpStatus = a} :: ListWorkteamsResponse) -- | An array of @Workteam@ objects, each describing a work team. listWorkteamsResponse_workteams :: Lens.Lens' ListWorkteamsResponse [Workteam] listWorkteamsResponse_workteams = Lens.lens (\ListWorkteamsResponse' {workteams} -> workteams) (\s@ListWorkteamsResponse' {} a -> s {workteams = a} :: ListWorkteamsResponse) Prelude.. Lens.coerced instance Prelude.NFData ListWorkteamsResponse where rnf ListWorkteamsResponse' {..} = Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus `Prelude.seq` Prelude.rnf workteams