{-# 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.DescribeAssociationExecutions -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Views all executions for a specific association ID. -- -- This operation returns paginated results. module Amazonka.SSM.DescribeAssociationExecutions ( -- * Creating a Request DescribeAssociationExecutions (..), newDescribeAssociationExecutions, -- * Request Lenses describeAssociationExecutions_filters, describeAssociationExecutions_maxResults, describeAssociationExecutions_nextToken, describeAssociationExecutions_associationId, -- * Destructuring the Response DescribeAssociationExecutionsResponse (..), newDescribeAssociationExecutionsResponse, -- * Response Lenses describeAssociationExecutionsResponse_associationExecutions, describeAssociationExecutionsResponse_nextToken, describeAssociationExecutionsResponse_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:/ 'newDescribeAssociationExecutions' smart constructor. data DescribeAssociationExecutions = DescribeAssociationExecutions' { -- | Filters for the request. You can specify the following filters and -- values. -- -- ExecutionId (EQUAL) -- -- Status (EQUAL) -- -- CreatedTime (EQUAL, GREATER_THAN, LESS_THAN) filters :: Prelude.Maybe (Prelude.NonEmpty AssociationExecutionFilter), -- | 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, -- | A token to start the list. Use this token to get the next set of -- results. nextToken :: Prelude.Maybe Prelude.Text, -- | The association ID for which you want to view execution history details. associationId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeAssociationExecutions' 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', 'describeAssociationExecutions_filters' - Filters for the request. You can specify the following filters and -- values. -- -- ExecutionId (EQUAL) -- -- Status (EQUAL) -- -- CreatedTime (EQUAL, GREATER_THAN, LESS_THAN) -- -- 'maxResults', 'describeAssociationExecutions_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', 'describeAssociationExecutions_nextToken' - A token to start the list. Use this token to get the next set of -- results. -- -- 'associationId', 'describeAssociationExecutions_associationId' - The association ID for which you want to view execution history details. newDescribeAssociationExecutions :: -- | 'associationId' Prelude.Text -> DescribeAssociationExecutions newDescribeAssociationExecutions pAssociationId_ = DescribeAssociationExecutions' { filters = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing, associationId = pAssociationId_ } -- | Filters for the request. You can specify the following filters and -- values. -- -- ExecutionId (EQUAL) -- -- Status (EQUAL) -- -- CreatedTime (EQUAL, GREATER_THAN, LESS_THAN) describeAssociationExecutions_filters :: Lens.Lens' DescribeAssociationExecutions (Prelude.Maybe (Prelude.NonEmpty AssociationExecutionFilter)) describeAssociationExecutions_filters = Lens.lens (\DescribeAssociationExecutions' {filters} -> filters) (\s@DescribeAssociationExecutions' {} a -> s {filters = a} :: DescribeAssociationExecutions) 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. describeAssociationExecutions_maxResults :: Lens.Lens' DescribeAssociationExecutions (Prelude.Maybe Prelude.Natural) describeAssociationExecutions_maxResults = Lens.lens (\DescribeAssociationExecutions' {maxResults} -> maxResults) (\s@DescribeAssociationExecutions' {} a -> s {maxResults = a} :: DescribeAssociationExecutions) -- | A token to start the list. Use this token to get the next set of -- results. describeAssociationExecutions_nextToken :: Lens.Lens' DescribeAssociationExecutions (Prelude.Maybe Prelude.Text) describeAssociationExecutions_nextToken = Lens.lens (\DescribeAssociationExecutions' {nextToken} -> nextToken) (\s@DescribeAssociationExecutions' {} a -> s {nextToken = a} :: DescribeAssociationExecutions) -- | The association ID for which you want to view execution history details. describeAssociationExecutions_associationId :: Lens.Lens' DescribeAssociationExecutions Prelude.Text describeAssociationExecutions_associationId = Lens.lens (\DescribeAssociationExecutions' {associationId} -> associationId) (\s@DescribeAssociationExecutions' {} a -> s {associationId = a} :: DescribeAssociationExecutions) instance Core.AWSPager DescribeAssociationExecutions where page rq rs | Core.stop ( rs Lens.^? describeAssociationExecutionsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? describeAssociationExecutionsResponse_associationExecutions Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& describeAssociationExecutions_nextToken Lens..~ rs Lens.^? describeAssociationExecutionsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest DescribeAssociationExecutions where type AWSResponse DescribeAssociationExecutions = DescribeAssociationExecutionsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DescribeAssociationExecutionsResponse' Prelude.<$> ( x Data..?> "AssociationExecutions" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "NextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DescribeAssociationExecutions where hashWithSalt _salt DescribeAssociationExecutions' {..} = _salt `Prelude.hashWithSalt` filters `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` associationId instance Prelude.NFData DescribeAssociationExecutions where rnf DescribeAssociationExecutions' {..} = Prelude.rnf filters `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf associationId instance Data.ToHeaders DescribeAssociationExecutions where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AmazonSSM.DescribeAssociationExecutions" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DescribeAssociationExecutions where toJSON DescribeAssociationExecutions' {..} = Data.object ( Prelude.catMaybes [ ("Filters" Data..=) Prelude.<$> filters, ("MaxResults" Data..=) Prelude.<$> maxResults, ("NextToken" Data..=) Prelude.<$> nextToken, Prelude.Just ("AssociationId" Data..= associationId) ] ) instance Data.ToPath DescribeAssociationExecutions where toPath = Prelude.const "/" instance Data.ToQuery DescribeAssociationExecutions where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDescribeAssociationExecutionsResponse' smart constructor. data DescribeAssociationExecutionsResponse = DescribeAssociationExecutionsResponse' { -- | A list of the executions for the specified association ID. associationExecutions :: Prelude.Maybe [AssociationExecution], -- | The token for the next set of items to return. Use this token to get the -- next set of results. 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 'DescribeAssociationExecutionsResponse' 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: -- -- 'associationExecutions', 'describeAssociationExecutionsResponse_associationExecutions' - A list of the executions for the specified association ID. -- -- 'nextToken', 'describeAssociationExecutionsResponse_nextToken' - The token for the next set of items to return. Use this token to get the -- next set of results. -- -- 'httpStatus', 'describeAssociationExecutionsResponse_httpStatus' - The response's http status code. newDescribeAssociationExecutionsResponse :: -- | 'httpStatus' Prelude.Int -> DescribeAssociationExecutionsResponse newDescribeAssociationExecutionsResponse pHttpStatus_ = DescribeAssociationExecutionsResponse' { associationExecutions = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | A list of the executions for the specified association ID. describeAssociationExecutionsResponse_associationExecutions :: Lens.Lens' DescribeAssociationExecutionsResponse (Prelude.Maybe [AssociationExecution]) describeAssociationExecutionsResponse_associationExecutions = Lens.lens (\DescribeAssociationExecutionsResponse' {associationExecutions} -> associationExecutions) (\s@DescribeAssociationExecutionsResponse' {} a -> s {associationExecutions = a} :: DescribeAssociationExecutionsResponse) Prelude.. Lens.mapping Lens.coerced -- | The token for the next set of items to return. Use this token to get the -- next set of results. describeAssociationExecutionsResponse_nextToken :: Lens.Lens' DescribeAssociationExecutionsResponse (Prelude.Maybe Prelude.Text) describeAssociationExecutionsResponse_nextToken = Lens.lens (\DescribeAssociationExecutionsResponse' {nextToken} -> nextToken) (\s@DescribeAssociationExecutionsResponse' {} a -> s {nextToken = a} :: DescribeAssociationExecutionsResponse) -- | The response's http status code. describeAssociationExecutionsResponse_httpStatus :: Lens.Lens' DescribeAssociationExecutionsResponse Prelude.Int describeAssociationExecutionsResponse_httpStatus = Lens.lens (\DescribeAssociationExecutionsResponse' {httpStatus} -> httpStatus) (\s@DescribeAssociationExecutionsResponse' {} a -> s {httpStatus = a} :: DescribeAssociationExecutionsResponse) instance Prelude.NFData DescribeAssociationExecutionsResponse where rnf DescribeAssociationExecutionsResponse' {..} = Prelude.rnf associationExecutions `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus