{-# 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.DescribeMaintenanceWindowExecutionTaskInvocations -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Retrieves the individual task executions (one per target) for a -- particular task run as part of a maintenance window execution. -- -- This operation returns paginated results. module Amazonka.SSM.DescribeMaintenanceWindowExecutionTaskInvocations ( -- * Creating a Request DescribeMaintenanceWindowExecutionTaskInvocations (..), newDescribeMaintenanceWindowExecutionTaskInvocations, -- * Request Lenses describeMaintenanceWindowExecutionTaskInvocations_filters, describeMaintenanceWindowExecutionTaskInvocations_maxResults, describeMaintenanceWindowExecutionTaskInvocations_nextToken, describeMaintenanceWindowExecutionTaskInvocations_windowExecutionId, describeMaintenanceWindowExecutionTaskInvocations_taskId, -- * Destructuring the Response DescribeMaintenanceWindowExecutionTaskInvocationsResponse (..), newDescribeMaintenanceWindowExecutionTaskInvocationsResponse, -- * Response Lenses describeMaintenanceWindowExecutionTaskInvocationsResponse_nextToken, describeMaintenanceWindowExecutionTaskInvocationsResponse_windowExecutionTaskInvocationIdentities, describeMaintenanceWindowExecutionTaskInvocationsResponse_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:/ 'newDescribeMaintenanceWindowExecutionTaskInvocations' smart constructor. data DescribeMaintenanceWindowExecutionTaskInvocations = DescribeMaintenanceWindowExecutionTaskInvocations' { -- | Optional filters used to scope down the returned task invocations. The -- supported filter key is @STATUS@ with the corresponding values -- @PENDING@, @IN_PROGRESS@, @SUCCESS@, @FAILED@, @TIMED_OUT@, -- @CANCELLING@, and @CANCELLED@. filters :: Prelude.Maybe [MaintenanceWindowFilter], -- | 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, -- | The ID of the maintenance window execution the task is part of. windowExecutionId :: Prelude.Text, -- | The ID of the specific task in the maintenance window task that should -- be retrieved. taskId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeMaintenanceWindowExecutionTaskInvocations' 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', 'describeMaintenanceWindowExecutionTaskInvocations_filters' - Optional filters used to scope down the returned task invocations. The -- supported filter key is @STATUS@ with the corresponding values -- @PENDING@, @IN_PROGRESS@, @SUCCESS@, @FAILED@, @TIMED_OUT@, -- @CANCELLING@, and @CANCELLED@. -- -- 'maxResults', 'describeMaintenanceWindowExecutionTaskInvocations_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', 'describeMaintenanceWindowExecutionTaskInvocations_nextToken' - The token for the next set of items to return. (You received this token -- from a previous call.) -- -- 'windowExecutionId', 'describeMaintenanceWindowExecutionTaskInvocations_windowExecutionId' - The ID of the maintenance window execution the task is part of. -- -- 'taskId', 'describeMaintenanceWindowExecutionTaskInvocations_taskId' - The ID of the specific task in the maintenance window task that should -- be retrieved. newDescribeMaintenanceWindowExecutionTaskInvocations :: -- | 'windowExecutionId' Prelude.Text -> -- | 'taskId' Prelude.Text -> DescribeMaintenanceWindowExecutionTaskInvocations newDescribeMaintenanceWindowExecutionTaskInvocations pWindowExecutionId_ pTaskId_ = DescribeMaintenanceWindowExecutionTaskInvocations' { filters = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing, windowExecutionId = pWindowExecutionId_, taskId = pTaskId_ } -- | Optional filters used to scope down the returned task invocations. The -- supported filter key is @STATUS@ with the corresponding values -- @PENDING@, @IN_PROGRESS@, @SUCCESS@, @FAILED@, @TIMED_OUT@, -- @CANCELLING@, and @CANCELLED@. describeMaintenanceWindowExecutionTaskInvocations_filters :: Lens.Lens' DescribeMaintenanceWindowExecutionTaskInvocations (Prelude.Maybe [MaintenanceWindowFilter]) describeMaintenanceWindowExecutionTaskInvocations_filters = Lens.lens (\DescribeMaintenanceWindowExecutionTaskInvocations' {filters} -> filters) (\s@DescribeMaintenanceWindowExecutionTaskInvocations' {} a -> s {filters = a} :: DescribeMaintenanceWindowExecutionTaskInvocations) 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. describeMaintenanceWindowExecutionTaskInvocations_maxResults :: Lens.Lens' DescribeMaintenanceWindowExecutionTaskInvocations (Prelude.Maybe Prelude.Natural) describeMaintenanceWindowExecutionTaskInvocations_maxResults = Lens.lens (\DescribeMaintenanceWindowExecutionTaskInvocations' {maxResults} -> maxResults) (\s@DescribeMaintenanceWindowExecutionTaskInvocations' {} a -> s {maxResults = a} :: DescribeMaintenanceWindowExecutionTaskInvocations) -- | The token for the next set of items to return. (You received this token -- from a previous call.) describeMaintenanceWindowExecutionTaskInvocations_nextToken :: Lens.Lens' DescribeMaintenanceWindowExecutionTaskInvocations (Prelude.Maybe Prelude.Text) describeMaintenanceWindowExecutionTaskInvocations_nextToken = Lens.lens (\DescribeMaintenanceWindowExecutionTaskInvocations' {nextToken} -> nextToken) (\s@DescribeMaintenanceWindowExecutionTaskInvocations' {} a -> s {nextToken = a} :: DescribeMaintenanceWindowExecutionTaskInvocations) -- | The ID of the maintenance window execution the task is part of. describeMaintenanceWindowExecutionTaskInvocations_windowExecutionId :: Lens.Lens' DescribeMaintenanceWindowExecutionTaskInvocations Prelude.Text describeMaintenanceWindowExecutionTaskInvocations_windowExecutionId = Lens.lens (\DescribeMaintenanceWindowExecutionTaskInvocations' {windowExecutionId} -> windowExecutionId) (\s@DescribeMaintenanceWindowExecutionTaskInvocations' {} a -> s {windowExecutionId = a} :: DescribeMaintenanceWindowExecutionTaskInvocations) -- | The ID of the specific task in the maintenance window task that should -- be retrieved. describeMaintenanceWindowExecutionTaskInvocations_taskId :: Lens.Lens' DescribeMaintenanceWindowExecutionTaskInvocations Prelude.Text describeMaintenanceWindowExecutionTaskInvocations_taskId = Lens.lens (\DescribeMaintenanceWindowExecutionTaskInvocations' {taskId} -> taskId) (\s@DescribeMaintenanceWindowExecutionTaskInvocations' {} a -> s {taskId = a} :: DescribeMaintenanceWindowExecutionTaskInvocations) instance Core.AWSPager DescribeMaintenanceWindowExecutionTaskInvocations where page rq rs | Core.stop ( rs Lens.^? describeMaintenanceWindowExecutionTaskInvocationsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? describeMaintenanceWindowExecutionTaskInvocationsResponse_windowExecutionTaskInvocationIdentities Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& describeMaintenanceWindowExecutionTaskInvocations_nextToken Lens..~ rs Lens.^? describeMaintenanceWindowExecutionTaskInvocationsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest DescribeMaintenanceWindowExecutionTaskInvocations where type AWSResponse DescribeMaintenanceWindowExecutionTaskInvocations = DescribeMaintenanceWindowExecutionTaskInvocationsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DescribeMaintenanceWindowExecutionTaskInvocationsResponse' Prelude.<$> (x Data..?> "NextToken") Prelude.<*> ( x Data..?> "WindowExecutionTaskInvocationIdentities" Core..!@ Prelude.mempty ) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DescribeMaintenanceWindowExecutionTaskInvocations where hashWithSalt _salt DescribeMaintenanceWindowExecutionTaskInvocations' {..} = _salt `Prelude.hashWithSalt` filters `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` windowExecutionId `Prelude.hashWithSalt` taskId instance Prelude.NFData DescribeMaintenanceWindowExecutionTaskInvocations where rnf DescribeMaintenanceWindowExecutionTaskInvocations' {..} = Prelude.rnf filters `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf windowExecutionId `Prelude.seq` Prelude.rnf taskId instance Data.ToHeaders DescribeMaintenanceWindowExecutionTaskInvocations where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AmazonSSM.DescribeMaintenanceWindowExecutionTaskInvocations" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DescribeMaintenanceWindowExecutionTaskInvocations where toJSON DescribeMaintenanceWindowExecutionTaskInvocations' {..} = Data.object ( Prelude.catMaybes [ ("Filters" Data..=) Prelude.<$> filters, ("MaxResults" Data..=) Prelude.<$> maxResults, ("NextToken" Data..=) Prelude.<$> nextToken, Prelude.Just ("WindowExecutionId" Data..= windowExecutionId), Prelude.Just ("TaskId" Data..= taskId) ] ) instance Data.ToPath DescribeMaintenanceWindowExecutionTaskInvocations where toPath = Prelude.const "/" instance Data.ToQuery DescribeMaintenanceWindowExecutionTaskInvocations where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDescribeMaintenanceWindowExecutionTaskInvocationsResponse' smart constructor. data DescribeMaintenanceWindowExecutionTaskInvocationsResponse = DescribeMaintenanceWindowExecutionTaskInvocationsResponse' { -- | 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, -- | Information about the task invocation results per invocation. windowExecutionTaskInvocationIdentities :: Prelude.Maybe [MaintenanceWindowExecutionTaskInvocationIdentity], -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeMaintenanceWindowExecutionTaskInvocationsResponse' 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', 'describeMaintenanceWindowExecutionTaskInvocationsResponse_nextToken' - The token to use when requesting the next set of items. If there are no -- additional items to return, the string is empty. -- -- 'windowExecutionTaskInvocationIdentities', 'describeMaintenanceWindowExecutionTaskInvocationsResponse_windowExecutionTaskInvocationIdentities' - Information about the task invocation results per invocation. -- -- 'httpStatus', 'describeMaintenanceWindowExecutionTaskInvocationsResponse_httpStatus' - The response's http status code. newDescribeMaintenanceWindowExecutionTaskInvocationsResponse :: -- | 'httpStatus' Prelude.Int -> DescribeMaintenanceWindowExecutionTaskInvocationsResponse newDescribeMaintenanceWindowExecutionTaskInvocationsResponse pHttpStatus_ = DescribeMaintenanceWindowExecutionTaskInvocationsResponse' { nextToken = Prelude.Nothing, windowExecutionTaskInvocationIdentities = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The token to use when requesting the next set of items. If there are no -- additional items to return, the string is empty. describeMaintenanceWindowExecutionTaskInvocationsResponse_nextToken :: Lens.Lens' DescribeMaintenanceWindowExecutionTaskInvocationsResponse (Prelude.Maybe Prelude.Text) describeMaintenanceWindowExecutionTaskInvocationsResponse_nextToken = Lens.lens (\DescribeMaintenanceWindowExecutionTaskInvocationsResponse' {nextToken} -> nextToken) (\s@DescribeMaintenanceWindowExecutionTaskInvocationsResponse' {} a -> s {nextToken = a} :: DescribeMaintenanceWindowExecutionTaskInvocationsResponse) -- | Information about the task invocation results per invocation. describeMaintenanceWindowExecutionTaskInvocationsResponse_windowExecutionTaskInvocationIdentities :: Lens.Lens' DescribeMaintenanceWindowExecutionTaskInvocationsResponse (Prelude.Maybe [MaintenanceWindowExecutionTaskInvocationIdentity]) describeMaintenanceWindowExecutionTaskInvocationsResponse_windowExecutionTaskInvocationIdentities = Lens.lens (\DescribeMaintenanceWindowExecutionTaskInvocationsResponse' {windowExecutionTaskInvocationIdentities} -> windowExecutionTaskInvocationIdentities) (\s@DescribeMaintenanceWindowExecutionTaskInvocationsResponse' {} a -> s {windowExecutionTaskInvocationIdentities = a} :: DescribeMaintenanceWindowExecutionTaskInvocationsResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. describeMaintenanceWindowExecutionTaskInvocationsResponse_httpStatus :: Lens.Lens' DescribeMaintenanceWindowExecutionTaskInvocationsResponse Prelude.Int describeMaintenanceWindowExecutionTaskInvocationsResponse_httpStatus = Lens.lens (\DescribeMaintenanceWindowExecutionTaskInvocationsResponse' {httpStatus} -> httpStatus) (\s@DescribeMaintenanceWindowExecutionTaskInvocationsResponse' {} a -> s {httpStatus = a} :: DescribeMaintenanceWindowExecutionTaskInvocationsResponse) instance Prelude.NFData DescribeMaintenanceWindowExecutionTaskInvocationsResponse where rnf DescribeMaintenanceWindowExecutionTaskInvocationsResponse' {..} = Prelude.rnf nextToken `Prelude.seq` Prelude.rnf windowExecutionTaskInvocationIdentities `Prelude.seq` Prelude.rnf httpStatus