{-# 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.SSM.DescribeAutomationExecutions -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Provides details about all active and terminated Automation executions. -- -- This operation returns paginated results. module Amazonka.SSM.DescribeAutomationExecutions ( -- * Creating a Request DescribeAutomationExecutions (..), newDescribeAutomationExecutions, -- * Request Lenses describeAutomationExecutions_filters, describeAutomationExecutions_maxResults, describeAutomationExecutions_nextToken, -- * Destructuring the Response DescribeAutomationExecutionsResponse (..), newDescribeAutomationExecutionsResponse, -- * Response Lenses describeAutomationExecutionsResponse_automationExecutionMetadataList, describeAutomationExecutionsResponse_nextToken, describeAutomationExecutionsResponse_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.SSM.Types -- | /See:/ 'newDescribeAutomationExecutions' smart constructor. data DescribeAutomationExecutions = DescribeAutomationExecutions' { -- | Filters used to limit the scope of executions that are requested. filters :: Prelude.Maybe (Prelude.NonEmpty AutomationExecutionFilter), -- | The maximum number of items to return for this call. The call also -- returns a token that you can specify in a subsequent call to get the -- next set of results. maxResults :: Prelude.Maybe Prelude.Natural, -- | The token for the next set of items to return. (You received this token -- from a previous call.) nextToken :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeAutomationExecutions' 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: -- -- 'filters', 'describeAutomationExecutions_filters' - Filters used to limit the scope of executions that are requested. -- -- 'maxResults', 'describeAutomationExecutions_maxResults' - The maximum number of items to return for this call. The call also -- returns a token that you can specify in a subsequent call to get the -- next set of results. -- -- 'nextToken', 'describeAutomationExecutions_nextToken' - The token for the next set of items to return. (You received this token -- from a previous call.) newDescribeAutomationExecutions :: DescribeAutomationExecutions newDescribeAutomationExecutions = DescribeAutomationExecutions' { filters = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing } -- | Filters used to limit the scope of executions that are requested. describeAutomationExecutions_filters :: Lens.Lens' DescribeAutomationExecutions (Prelude.Maybe (Prelude.NonEmpty AutomationExecutionFilter)) describeAutomationExecutions_filters = Lens.lens (\DescribeAutomationExecutions' {filters} -> filters) (\s@DescribeAutomationExecutions' {} a -> s {filters = a} :: DescribeAutomationExecutions) Prelude.. Lens.mapping Lens.coerced -- | The maximum number of items to return for this call. The call also -- returns a token that you can specify in a subsequent call to get the -- next set of results. describeAutomationExecutions_maxResults :: Lens.Lens' DescribeAutomationExecutions (Prelude.Maybe Prelude.Natural) describeAutomationExecutions_maxResults = Lens.lens (\DescribeAutomationExecutions' {maxResults} -> maxResults) (\s@DescribeAutomationExecutions' {} a -> s {maxResults = a} :: DescribeAutomationExecutions) -- | The token for the next set of items to return. (You received this token -- from a previous call.) describeAutomationExecutions_nextToken :: Lens.Lens' DescribeAutomationExecutions (Prelude.Maybe Prelude.Text) describeAutomationExecutions_nextToken = Lens.lens (\DescribeAutomationExecutions' {nextToken} -> nextToken) (\s@DescribeAutomationExecutions' {} a -> s {nextToken = a} :: DescribeAutomationExecutions) instance Core.AWSPager DescribeAutomationExecutions where page rq rs | Core.stop ( rs Lens.^? describeAutomationExecutionsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? describeAutomationExecutionsResponse_automationExecutionMetadataList Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& describeAutomationExecutions_nextToken Lens..~ rs Lens.^? describeAutomationExecutionsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest DescribeAutomationExecutions where type AWSResponse DescribeAutomationExecutions = DescribeAutomationExecutionsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DescribeAutomationExecutionsResponse' Prelude.<$> ( x Data..?> "AutomationExecutionMetadataList" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "NextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DescribeAutomationExecutions where hashWithSalt _salt DescribeAutomationExecutions' {..} = _salt `Prelude.hashWithSalt` filters `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken instance Prelude.NFData DescribeAutomationExecutions where rnf DescribeAutomationExecutions' {..} = Prelude.rnf filters `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken instance Data.ToHeaders DescribeAutomationExecutions where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AmazonSSM.DescribeAutomationExecutions" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DescribeAutomationExecutions where toJSON DescribeAutomationExecutions' {..} = Data.object ( Prelude.catMaybes [ ("Filters" Data..=) Prelude.<$> filters, ("MaxResults" Data..=) Prelude.<$> maxResults, ("NextToken" Data..=) Prelude.<$> nextToken ] ) instance Data.ToPath DescribeAutomationExecutions where toPath = Prelude.const "/" instance Data.ToQuery DescribeAutomationExecutions where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDescribeAutomationExecutionsResponse' smart constructor. data DescribeAutomationExecutionsResponse = DescribeAutomationExecutionsResponse' { -- | The list of details about each automation execution which has occurred -- which matches the filter specification, if any. automationExecutionMetadataList :: Prelude.Maybe [AutomationExecutionMetadata], -- | The token to use when requesting the next set of items. If there are no -- additional items to return, the string is empty. 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 'DescribeAutomationExecutionsResponse' 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: -- -- 'automationExecutionMetadataList', 'describeAutomationExecutionsResponse_automationExecutionMetadataList' - The list of details about each automation execution which has occurred -- which matches the filter specification, if any. -- -- 'nextToken', 'describeAutomationExecutionsResponse_nextToken' - The token to use when requesting the next set of items. If there are no -- additional items to return, the string is empty. -- -- 'httpStatus', 'describeAutomationExecutionsResponse_httpStatus' - The response's http status code. newDescribeAutomationExecutionsResponse :: -- | 'httpStatus' Prelude.Int -> DescribeAutomationExecutionsResponse newDescribeAutomationExecutionsResponse pHttpStatus_ = DescribeAutomationExecutionsResponse' { automationExecutionMetadataList = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The list of details about each automation execution which has occurred -- which matches the filter specification, if any. describeAutomationExecutionsResponse_automationExecutionMetadataList :: Lens.Lens' DescribeAutomationExecutionsResponse (Prelude.Maybe [AutomationExecutionMetadata]) describeAutomationExecutionsResponse_automationExecutionMetadataList = Lens.lens (\DescribeAutomationExecutionsResponse' {automationExecutionMetadataList} -> automationExecutionMetadataList) (\s@DescribeAutomationExecutionsResponse' {} a -> s {automationExecutionMetadataList = a} :: DescribeAutomationExecutionsResponse) Prelude.. Lens.mapping Lens.coerced -- | The token to use when requesting the next set of items. If there are no -- additional items to return, the string is empty. describeAutomationExecutionsResponse_nextToken :: Lens.Lens' DescribeAutomationExecutionsResponse (Prelude.Maybe Prelude.Text) describeAutomationExecutionsResponse_nextToken = Lens.lens (\DescribeAutomationExecutionsResponse' {nextToken} -> nextToken) (\s@DescribeAutomationExecutionsResponse' {} a -> s {nextToken = a} :: DescribeAutomationExecutionsResponse) -- | The response's http status code. describeAutomationExecutionsResponse_httpStatus :: Lens.Lens' DescribeAutomationExecutionsResponse Prelude.Int describeAutomationExecutionsResponse_httpStatus = Lens.lens (\DescribeAutomationExecutionsResponse' {httpStatus} -> httpStatus) (\s@DescribeAutomationExecutionsResponse' {} a -> s {httpStatus = a} :: DescribeAutomationExecutionsResponse) instance Prelude.NFData DescribeAutomationExecutionsResponse where rnf DescribeAutomationExecutionsResponse' {..} = Prelude.rnf automationExecutionMetadataList `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus