{-# 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.MGN.DescribeJobs -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Returns a list of Jobs. Use the JobsID and fromDate and toData filters -- to limit which jobs are returned. The response is sorted by -- creationDataTime - latest date first. Jobs are normally created by the -- StartTest, StartCutover, and TerminateTargetInstances APIs. Jobs are -- also created by DiagnosticLaunch and TerminateDiagnosticInstances, which -- are APIs available only to *Support* and only used in response to -- relevant support tickets. -- -- This operation returns paginated results. module Amazonka.MGN.DescribeJobs ( -- * Creating a Request DescribeJobs (..), newDescribeJobs, -- * Request Lenses describeJobs_filters, describeJobs_maxResults, describeJobs_nextToken, -- * Destructuring the Response DescribeJobsResponse (..), newDescribeJobsResponse, -- * Response Lenses describeJobsResponse_items, describeJobsResponse_nextToken, describeJobsResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.MGN.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newDescribeJobs' smart constructor. data DescribeJobs = DescribeJobs' { -- | Request to describe Job log filters. filters :: Prelude.Maybe DescribeJobsRequestFilters, -- | Request to describe job log items by max results. maxResults :: Prelude.Maybe Prelude.Natural, -- | Request to describe job log items by next token. nextToken :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeJobs' 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', 'describeJobs_filters' - Request to describe Job log filters. -- -- 'maxResults', 'describeJobs_maxResults' - Request to describe job log items by max results. -- -- 'nextToken', 'describeJobs_nextToken' - Request to describe job log items by next token. newDescribeJobs :: DescribeJobs newDescribeJobs = DescribeJobs' { filters = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing } -- | Request to describe Job log filters. describeJobs_filters :: Lens.Lens' DescribeJobs (Prelude.Maybe DescribeJobsRequestFilters) describeJobs_filters = Lens.lens (\DescribeJobs' {filters} -> filters) (\s@DescribeJobs' {} a -> s {filters = a} :: DescribeJobs) -- | Request to describe job log items by max results. describeJobs_maxResults :: Lens.Lens' DescribeJobs (Prelude.Maybe Prelude.Natural) describeJobs_maxResults = Lens.lens (\DescribeJobs' {maxResults} -> maxResults) (\s@DescribeJobs' {} a -> s {maxResults = a} :: DescribeJobs) -- | Request to describe job log items by next token. describeJobs_nextToken :: Lens.Lens' DescribeJobs (Prelude.Maybe Prelude.Text) describeJobs_nextToken = Lens.lens (\DescribeJobs' {nextToken} -> nextToken) (\s@DescribeJobs' {} a -> s {nextToken = a} :: DescribeJobs) instance Core.AWSPager DescribeJobs where page rq rs | Core.stop ( rs Lens.^? describeJobsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? describeJobsResponse_items Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& describeJobs_nextToken Lens..~ rs Lens.^? describeJobsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest DescribeJobs where type AWSResponse DescribeJobs = DescribeJobsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DescribeJobsResponse' Prelude.<$> (x Data..?> "items" Core..!@ Prelude.mempty) Prelude.<*> (x Data..?> "nextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DescribeJobs where hashWithSalt _salt DescribeJobs' {..} = _salt `Prelude.hashWithSalt` filters `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken instance Prelude.NFData DescribeJobs where rnf DescribeJobs' {..} = Prelude.rnf filters `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken instance Data.ToHeaders DescribeJobs where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DescribeJobs where toJSON DescribeJobs' {..} = Data.object ( Prelude.catMaybes [ ("filters" Data..=) Prelude.<$> filters, ("maxResults" Data..=) Prelude.<$> maxResults, ("nextToken" Data..=) Prelude.<$> nextToken ] ) instance Data.ToPath DescribeJobs where toPath = Prelude.const "/DescribeJobs" instance Data.ToQuery DescribeJobs where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDescribeJobsResponse' smart constructor. data DescribeJobsResponse = DescribeJobsResponse' { -- | Request to describe Job log items. items :: Prelude.Maybe [Job], -- | Request to describe Job response by next token. nextToken :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeJobsResponse' 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: -- -- 'items', 'describeJobsResponse_items' - Request to describe Job log items. -- -- 'nextToken', 'describeJobsResponse_nextToken' - Request to describe Job response by next token. -- -- 'httpStatus', 'describeJobsResponse_httpStatus' - The response's http status code. newDescribeJobsResponse :: -- | 'httpStatus' Prelude.Int -> DescribeJobsResponse newDescribeJobsResponse pHttpStatus_ = DescribeJobsResponse' { items = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Request to describe Job log items. describeJobsResponse_items :: Lens.Lens' DescribeJobsResponse (Prelude.Maybe [Job]) describeJobsResponse_items = Lens.lens (\DescribeJobsResponse' {items} -> items) (\s@DescribeJobsResponse' {} a -> s {items = a} :: DescribeJobsResponse) Prelude.. Lens.mapping Lens.coerced -- | Request to describe Job response by next token. describeJobsResponse_nextToken :: Lens.Lens' DescribeJobsResponse (Prelude.Maybe Prelude.Text) describeJobsResponse_nextToken = Lens.lens (\DescribeJobsResponse' {nextToken} -> nextToken) (\s@DescribeJobsResponse' {} a -> s {nextToken = a} :: DescribeJobsResponse) -- | The response's http status code. describeJobsResponse_httpStatus :: Lens.Lens' DescribeJobsResponse Prelude.Int describeJobsResponse_httpStatus = Lens.lens (\DescribeJobsResponse' {httpStatus} -> httpStatus) (\s@DescribeJobsResponse' {} a -> s {httpStatus = a} :: DescribeJobsResponse) instance Prelude.NFData DescribeJobsResponse where rnf DescribeJobsResponse' {..} = Prelude.rnf items `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus