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