{-# 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.ListActions -- 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 the actions in your account and their properties. -- -- This operation returns paginated results. module Amazonka.SageMaker.ListActions ( -- * Creating a Request ListActions (..), newListActions, -- * Request Lenses listActions_actionType, listActions_createdAfter, listActions_createdBefore, listActions_maxResults, listActions_nextToken, listActions_sortBy, listActions_sortOrder, listActions_sourceUri, -- * Destructuring the Response ListActionsResponse (..), newListActionsResponse, -- * Response Lenses listActionsResponse_actionSummaries, listActionsResponse_nextToken, listActionsResponse_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:/ 'newListActions' smart constructor. data ListActions = ListActions' { -- | A filter that returns only actions of the specified type. actionType :: Prelude.Maybe Prelude.Text, -- | A filter that returns only actions created on or after the specified -- time. createdAfter :: Prelude.Maybe Data.POSIX, -- | A filter that returns only actions created on or before the specified -- time. createdBefore :: Prelude.Maybe Data.POSIX, -- | The maximum number of actions to return in the response. The default -- value is 10. maxResults :: Prelude.Maybe Prelude.Natural, -- | If the previous call to @ListActions@ didn\'t return the full set of -- actions, the call returns a token for getting the next set of actions. nextToken :: Prelude.Maybe Prelude.Text, -- | The property used to sort results. The default value is @CreationTime@. sortBy :: Prelude.Maybe SortActionsBy, -- | The sort order. The default value is @Descending@. sortOrder :: Prelude.Maybe SortOrder, -- | A filter that returns only actions with the specified source URI. sourceUri :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListActions' 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: -- -- 'actionType', 'listActions_actionType' - A filter that returns only actions of the specified type. -- -- 'createdAfter', 'listActions_createdAfter' - A filter that returns only actions created on or after the specified -- time. -- -- 'createdBefore', 'listActions_createdBefore' - A filter that returns only actions created on or before the specified -- time. -- -- 'maxResults', 'listActions_maxResults' - The maximum number of actions to return in the response. The default -- value is 10. -- -- 'nextToken', 'listActions_nextToken' - If the previous call to @ListActions@ didn\'t return the full set of -- actions, the call returns a token for getting the next set of actions. -- -- 'sortBy', 'listActions_sortBy' - The property used to sort results. The default value is @CreationTime@. -- -- 'sortOrder', 'listActions_sortOrder' - The sort order. The default value is @Descending@. -- -- 'sourceUri', 'listActions_sourceUri' - A filter that returns only actions with the specified source URI. newListActions :: ListActions newListActions = ListActions' { actionType = Prelude.Nothing, createdAfter = Prelude.Nothing, createdBefore = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing, sortBy = Prelude.Nothing, sortOrder = Prelude.Nothing, sourceUri = Prelude.Nothing } -- | A filter that returns only actions of the specified type. listActions_actionType :: Lens.Lens' ListActions (Prelude.Maybe Prelude.Text) listActions_actionType = Lens.lens (\ListActions' {actionType} -> actionType) (\s@ListActions' {} a -> s {actionType = a} :: ListActions) -- | A filter that returns only actions created on or after the specified -- time. listActions_createdAfter :: Lens.Lens' ListActions (Prelude.Maybe Prelude.UTCTime) listActions_createdAfter = Lens.lens (\ListActions' {createdAfter} -> createdAfter) (\s@ListActions' {} a -> s {createdAfter = a} :: ListActions) Prelude.. Lens.mapping Data._Time -- | A filter that returns only actions created on or before the specified -- time. listActions_createdBefore :: Lens.Lens' ListActions (Prelude.Maybe Prelude.UTCTime) listActions_createdBefore = Lens.lens (\ListActions' {createdBefore} -> createdBefore) (\s@ListActions' {} a -> s {createdBefore = a} :: ListActions) Prelude.. Lens.mapping Data._Time -- | The maximum number of actions to return in the response. The default -- value is 10. listActions_maxResults :: Lens.Lens' ListActions (Prelude.Maybe Prelude.Natural) listActions_maxResults = Lens.lens (\ListActions' {maxResults} -> maxResults) (\s@ListActions' {} a -> s {maxResults = a} :: ListActions) -- | If the previous call to @ListActions@ didn\'t return the full set of -- actions, the call returns a token for getting the next set of actions. listActions_nextToken :: Lens.Lens' ListActions (Prelude.Maybe Prelude.Text) listActions_nextToken = Lens.lens (\ListActions' {nextToken} -> nextToken) (\s@ListActions' {} a -> s {nextToken = a} :: ListActions) -- | The property used to sort results. The default value is @CreationTime@. listActions_sortBy :: Lens.Lens' ListActions (Prelude.Maybe SortActionsBy) listActions_sortBy = Lens.lens (\ListActions' {sortBy} -> sortBy) (\s@ListActions' {} a -> s {sortBy = a} :: ListActions) -- | The sort order. The default value is @Descending@. listActions_sortOrder :: Lens.Lens' ListActions (Prelude.Maybe SortOrder) listActions_sortOrder = Lens.lens (\ListActions' {sortOrder} -> sortOrder) (\s@ListActions' {} a -> s {sortOrder = a} :: ListActions) -- | A filter that returns only actions with the specified source URI. listActions_sourceUri :: Lens.Lens' ListActions (Prelude.Maybe Prelude.Text) listActions_sourceUri = Lens.lens (\ListActions' {sourceUri} -> sourceUri) (\s@ListActions' {} a -> s {sourceUri = a} :: ListActions) instance Core.AWSPager ListActions where page rq rs | Core.stop ( rs Lens.^? listActionsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? listActionsResponse_actionSummaries Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& listActions_nextToken Lens..~ rs Lens.^? listActionsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest ListActions where type AWSResponse ListActions = ListActionsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListActionsResponse' Prelude.<$> ( x Data..?> "ActionSummaries" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "NextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListActions where hashWithSalt _salt ListActions' {..} = _salt `Prelude.hashWithSalt` actionType `Prelude.hashWithSalt` createdAfter `Prelude.hashWithSalt` createdBefore `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` sortBy `Prelude.hashWithSalt` sortOrder `Prelude.hashWithSalt` sourceUri instance Prelude.NFData ListActions where rnf ListActions' {..} = Prelude.rnf actionType `Prelude.seq` Prelude.rnf createdAfter `Prelude.seq` Prelude.rnf createdBefore `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf sortBy `Prelude.seq` Prelude.rnf sortOrder `Prelude.seq` Prelude.rnf sourceUri instance Data.ToHeaders ListActions where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ("SageMaker.ListActions" :: Prelude.ByteString), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListActions where toJSON ListActions' {..} = Data.object ( Prelude.catMaybes [ ("ActionType" Data..=) Prelude.<$> actionType, ("CreatedAfter" Data..=) Prelude.<$> createdAfter, ("CreatedBefore" Data..=) Prelude.<$> createdBefore, ("MaxResults" Data..=) Prelude.<$> maxResults, ("NextToken" Data..=) Prelude.<$> nextToken, ("SortBy" Data..=) Prelude.<$> sortBy, ("SortOrder" Data..=) Prelude.<$> sortOrder, ("SourceUri" Data..=) Prelude.<$> sourceUri ] ) instance Data.ToPath ListActions where toPath = Prelude.const "/" instance Data.ToQuery ListActions where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newListActionsResponse' smart constructor. data ListActionsResponse = ListActionsResponse' { -- | A list of actions and their properties. actionSummaries :: Prelude.Maybe [ActionSummary], -- | A token for getting the next set of actions, if there are any. 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 'ListActionsResponse' 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: -- -- 'actionSummaries', 'listActionsResponse_actionSummaries' - A list of actions and their properties. -- -- 'nextToken', 'listActionsResponse_nextToken' - A token for getting the next set of actions, if there are any. -- -- 'httpStatus', 'listActionsResponse_httpStatus' - The response's http status code. newListActionsResponse :: -- | 'httpStatus' Prelude.Int -> ListActionsResponse newListActionsResponse pHttpStatus_ = ListActionsResponse' { actionSummaries = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | A list of actions and their properties. listActionsResponse_actionSummaries :: Lens.Lens' ListActionsResponse (Prelude.Maybe [ActionSummary]) listActionsResponse_actionSummaries = Lens.lens (\ListActionsResponse' {actionSummaries} -> actionSummaries) (\s@ListActionsResponse' {} a -> s {actionSummaries = a} :: ListActionsResponse) Prelude.. Lens.mapping Lens.coerced -- | A token for getting the next set of actions, if there are any. listActionsResponse_nextToken :: Lens.Lens' ListActionsResponse (Prelude.Maybe Prelude.Text) listActionsResponse_nextToken = Lens.lens (\ListActionsResponse' {nextToken} -> nextToken) (\s@ListActionsResponse' {} a -> s {nextToken = a} :: ListActionsResponse) -- | The response's http status code. listActionsResponse_httpStatus :: Lens.Lens' ListActionsResponse Prelude.Int listActionsResponse_httpStatus = Lens.lens (\ListActionsResponse' {httpStatus} -> httpStatus) (\s@ListActionsResponse' {} a -> s {httpStatus = a} :: ListActionsResponse) instance Prelude.NFData ListActionsResponse where rnf ListActionsResponse' {..} = Prelude.rnf actionSummaries `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus