{-# 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.DescribeAssociationExecutionTargets -- 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 information about a specific execution of a specific association. -- -- This operation returns paginated results. module Amazonka.SSM.DescribeAssociationExecutionTargets ( -- * Creating a Request DescribeAssociationExecutionTargets (..), newDescribeAssociationExecutionTargets, -- * Request Lenses describeAssociationExecutionTargets_filters, describeAssociationExecutionTargets_maxResults, describeAssociationExecutionTargets_nextToken, describeAssociationExecutionTargets_associationId, describeAssociationExecutionTargets_executionId, -- * Destructuring the Response DescribeAssociationExecutionTargetsResponse (..), newDescribeAssociationExecutionTargetsResponse, -- * Response Lenses describeAssociationExecutionTargetsResponse_associationExecutionTargets, describeAssociationExecutionTargetsResponse_nextToken, describeAssociationExecutionTargetsResponse_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:/ 'newDescribeAssociationExecutionTargets' smart constructor. data DescribeAssociationExecutionTargets = DescribeAssociationExecutionTargets' { -- | Filters for the request. You can specify the following filters and -- values. -- -- Status (EQUAL) -- -- ResourceId (EQUAL) -- -- ResourceType (EQUAL) filters :: Prelude.Maybe (Prelude.NonEmpty AssociationExecutionTargetsFilter), -- | 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 that includes the execution for which you want to -- view details. associationId :: Prelude.Text, -- | The execution ID for which you want to view details. executionId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeAssociationExecutionTargets' 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', 'describeAssociationExecutionTargets_filters' - Filters for the request. You can specify the following filters and -- values. -- -- Status (EQUAL) -- -- ResourceId (EQUAL) -- -- ResourceType (EQUAL) -- -- 'maxResults', 'describeAssociationExecutionTargets_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', 'describeAssociationExecutionTargets_nextToken' - A token to start the list. Use this token to get the next set of -- results. -- -- 'associationId', 'describeAssociationExecutionTargets_associationId' - The association ID that includes the execution for which you want to -- view details. -- -- 'executionId', 'describeAssociationExecutionTargets_executionId' - The execution ID for which you want to view details. newDescribeAssociationExecutionTargets :: -- | 'associationId' Prelude.Text -> -- | 'executionId' Prelude.Text -> DescribeAssociationExecutionTargets newDescribeAssociationExecutionTargets pAssociationId_ pExecutionId_ = DescribeAssociationExecutionTargets' { filters = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing, associationId = pAssociationId_, executionId = pExecutionId_ } -- | Filters for the request. You can specify the following filters and -- values. -- -- Status (EQUAL) -- -- ResourceId (EQUAL) -- -- ResourceType (EQUAL) describeAssociationExecutionTargets_filters :: Lens.Lens' DescribeAssociationExecutionTargets (Prelude.Maybe (Prelude.NonEmpty AssociationExecutionTargetsFilter)) describeAssociationExecutionTargets_filters = Lens.lens (\DescribeAssociationExecutionTargets' {filters} -> filters) (\s@DescribeAssociationExecutionTargets' {} a -> s {filters = a} :: DescribeAssociationExecutionTargets) 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. describeAssociationExecutionTargets_maxResults :: Lens.Lens' DescribeAssociationExecutionTargets (Prelude.Maybe Prelude.Natural) describeAssociationExecutionTargets_maxResults = Lens.lens (\DescribeAssociationExecutionTargets' {maxResults} -> maxResults) (\s@DescribeAssociationExecutionTargets' {} a -> s {maxResults = a} :: DescribeAssociationExecutionTargets) -- | A token to start the list. Use this token to get the next set of -- results. describeAssociationExecutionTargets_nextToken :: Lens.Lens' DescribeAssociationExecutionTargets (Prelude.Maybe Prelude.Text) describeAssociationExecutionTargets_nextToken = Lens.lens (\DescribeAssociationExecutionTargets' {nextToken} -> nextToken) (\s@DescribeAssociationExecutionTargets' {} a -> s {nextToken = a} :: DescribeAssociationExecutionTargets) -- | The association ID that includes the execution for which you want to -- view details. describeAssociationExecutionTargets_associationId :: Lens.Lens' DescribeAssociationExecutionTargets Prelude.Text describeAssociationExecutionTargets_associationId = Lens.lens (\DescribeAssociationExecutionTargets' {associationId} -> associationId) (\s@DescribeAssociationExecutionTargets' {} a -> s {associationId = a} :: DescribeAssociationExecutionTargets) -- | The execution ID for which you want to view details. describeAssociationExecutionTargets_executionId :: Lens.Lens' DescribeAssociationExecutionTargets Prelude.Text describeAssociationExecutionTargets_executionId = Lens.lens (\DescribeAssociationExecutionTargets' {executionId} -> executionId) (\s@DescribeAssociationExecutionTargets' {} a -> s {executionId = a} :: DescribeAssociationExecutionTargets) instance Core.AWSPager DescribeAssociationExecutionTargets where page rq rs | Core.stop ( rs Lens.^? describeAssociationExecutionTargetsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? describeAssociationExecutionTargetsResponse_associationExecutionTargets Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& describeAssociationExecutionTargets_nextToken Lens..~ rs Lens.^? describeAssociationExecutionTargetsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest DescribeAssociationExecutionTargets where type AWSResponse DescribeAssociationExecutionTargets = DescribeAssociationExecutionTargetsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DescribeAssociationExecutionTargetsResponse' Prelude.<$> ( x Data..?> "AssociationExecutionTargets" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "NextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DescribeAssociationExecutionTargets where hashWithSalt _salt DescribeAssociationExecutionTargets' {..} = _salt `Prelude.hashWithSalt` filters `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` associationId `Prelude.hashWithSalt` executionId instance Prelude.NFData DescribeAssociationExecutionTargets where rnf DescribeAssociationExecutionTargets' {..} = Prelude.rnf filters `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf associationId `Prelude.seq` Prelude.rnf executionId instance Data.ToHeaders DescribeAssociationExecutionTargets where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AmazonSSM.DescribeAssociationExecutionTargets" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DescribeAssociationExecutionTargets where toJSON DescribeAssociationExecutionTargets' {..} = Data.object ( Prelude.catMaybes [ ("Filters" Data..=) Prelude.<$> filters, ("MaxResults" Data..=) Prelude.<$> maxResults, ("NextToken" Data..=) Prelude.<$> nextToken, Prelude.Just ("AssociationId" Data..= associationId), Prelude.Just ("ExecutionId" Data..= executionId) ] ) instance Data.ToPath DescribeAssociationExecutionTargets where toPath = Prelude.const "/" instance Data.ToQuery DescribeAssociationExecutionTargets where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDescribeAssociationExecutionTargetsResponse' smart constructor. data DescribeAssociationExecutionTargetsResponse = DescribeAssociationExecutionTargetsResponse' { -- | Information about the execution. associationExecutionTargets :: Prelude.Maybe [AssociationExecutionTarget], -- | 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 'DescribeAssociationExecutionTargetsResponse' 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: -- -- 'associationExecutionTargets', 'describeAssociationExecutionTargetsResponse_associationExecutionTargets' - Information about the execution. -- -- 'nextToken', 'describeAssociationExecutionTargetsResponse_nextToken' - The token for the next set of items to return. Use this token to get the -- next set of results. -- -- 'httpStatus', 'describeAssociationExecutionTargetsResponse_httpStatus' - The response's http status code. newDescribeAssociationExecutionTargetsResponse :: -- | 'httpStatus' Prelude.Int -> DescribeAssociationExecutionTargetsResponse newDescribeAssociationExecutionTargetsResponse pHttpStatus_ = DescribeAssociationExecutionTargetsResponse' { associationExecutionTargets = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Information about the execution. describeAssociationExecutionTargetsResponse_associationExecutionTargets :: Lens.Lens' DescribeAssociationExecutionTargetsResponse (Prelude.Maybe [AssociationExecutionTarget]) describeAssociationExecutionTargetsResponse_associationExecutionTargets = Lens.lens (\DescribeAssociationExecutionTargetsResponse' {associationExecutionTargets} -> associationExecutionTargets) (\s@DescribeAssociationExecutionTargetsResponse' {} a -> s {associationExecutionTargets = a} :: DescribeAssociationExecutionTargetsResponse) 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. describeAssociationExecutionTargetsResponse_nextToken :: Lens.Lens' DescribeAssociationExecutionTargetsResponse (Prelude.Maybe Prelude.Text) describeAssociationExecutionTargetsResponse_nextToken = Lens.lens (\DescribeAssociationExecutionTargetsResponse' {nextToken} -> nextToken) (\s@DescribeAssociationExecutionTargetsResponse' {} a -> s {nextToken = a} :: DescribeAssociationExecutionTargetsResponse) -- | The response's http status code. describeAssociationExecutionTargetsResponse_httpStatus :: Lens.Lens' DescribeAssociationExecutionTargetsResponse Prelude.Int describeAssociationExecutionTargetsResponse_httpStatus = Lens.lens (\DescribeAssociationExecutionTargetsResponse' {httpStatus} -> httpStatus) (\s@DescribeAssociationExecutionTargetsResponse' {} a -> s {httpStatus = a} :: DescribeAssociationExecutionTargetsResponse) instance Prelude.NFData DescribeAssociationExecutionTargetsResponse where rnf DescribeAssociationExecutionTargetsResponse' {..} = Prelude.rnf associationExecutionTargets `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus