{-# 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.Glue.GetJobRun -- 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 metadata for a given job run. module Amazonka.Glue.GetJobRun ( -- * Creating a Request GetJobRun (..), newGetJobRun, -- * Request Lenses getJobRun_predecessorsIncluded, getJobRun_jobName, getJobRun_runId, -- * Destructuring the Response GetJobRunResponse (..), newGetJobRunResponse, -- * Response Lenses getJobRunResponse_jobRun, getJobRunResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.Glue.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newGetJobRun' smart constructor. data GetJobRun = GetJobRun' { -- | True if a list of predecessor runs should be returned. predecessorsIncluded :: Prelude.Maybe Prelude.Bool, -- | Name of the job definition being run. jobName :: Prelude.Text, -- | The ID of the job run. runId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetJobRun' 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: -- -- 'predecessorsIncluded', 'getJobRun_predecessorsIncluded' - True if a list of predecessor runs should be returned. -- -- 'jobName', 'getJobRun_jobName' - Name of the job definition being run. -- -- 'runId', 'getJobRun_runId' - The ID of the job run. newGetJobRun :: -- | 'jobName' Prelude.Text -> -- | 'runId' Prelude.Text -> GetJobRun newGetJobRun pJobName_ pRunId_ = GetJobRun' { predecessorsIncluded = Prelude.Nothing, jobName = pJobName_, runId = pRunId_ } -- | True if a list of predecessor runs should be returned. getJobRun_predecessorsIncluded :: Lens.Lens' GetJobRun (Prelude.Maybe Prelude.Bool) getJobRun_predecessorsIncluded = Lens.lens (\GetJobRun' {predecessorsIncluded} -> predecessorsIncluded) (\s@GetJobRun' {} a -> s {predecessorsIncluded = a} :: GetJobRun) -- | Name of the job definition being run. getJobRun_jobName :: Lens.Lens' GetJobRun Prelude.Text getJobRun_jobName = Lens.lens (\GetJobRun' {jobName} -> jobName) (\s@GetJobRun' {} a -> s {jobName = a} :: GetJobRun) -- | The ID of the job run. getJobRun_runId :: Lens.Lens' GetJobRun Prelude.Text getJobRun_runId = Lens.lens (\GetJobRun' {runId} -> runId) (\s@GetJobRun' {} a -> s {runId = a} :: GetJobRun) instance Core.AWSRequest GetJobRun where type AWSResponse GetJobRun = GetJobRunResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> GetJobRunResponse' Prelude.<$> (x Data..?> "JobRun") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable GetJobRun where hashWithSalt _salt GetJobRun' {..} = _salt `Prelude.hashWithSalt` predecessorsIncluded `Prelude.hashWithSalt` jobName `Prelude.hashWithSalt` runId instance Prelude.NFData GetJobRun where rnf GetJobRun' {..} = Prelude.rnf predecessorsIncluded `Prelude.seq` Prelude.rnf jobName `Prelude.seq` Prelude.rnf runId instance Data.ToHeaders GetJobRun where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ("AWSGlue.GetJobRun" :: Prelude.ByteString), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON GetJobRun where toJSON GetJobRun' {..} = Data.object ( Prelude.catMaybes [ ("PredecessorsIncluded" Data..=) Prelude.<$> predecessorsIncluded, Prelude.Just ("JobName" Data..= jobName), Prelude.Just ("RunId" Data..= runId) ] ) instance Data.ToPath GetJobRun where toPath = Prelude.const "/" instance Data.ToQuery GetJobRun where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newGetJobRunResponse' smart constructor. data GetJobRunResponse = GetJobRunResponse' { -- | The requested job-run metadata. jobRun :: Prelude.Maybe JobRun, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetJobRunResponse' 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: -- -- 'jobRun', 'getJobRunResponse_jobRun' - The requested job-run metadata. -- -- 'httpStatus', 'getJobRunResponse_httpStatus' - The response's http status code. newGetJobRunResponse :: -- | 'httpStatus' Prelude.Int -> GetJobRunResponse newGetJobRunResponse pHttpStatus_ = GetJobRunResponse' { jobRun = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The requested job-run metadata. getJobRunResponse_jobRun :: Lens.Lens' GetJobRunResponse (Prelude.Maybe JobRun) getJobRunResponse_jobRun = Lens.lens (\GetJobRunResponse' {jobRun} -> jobRun) (\s@GetJobRunResponse' {} a -> s {jobRun = a} :: GetJobRunResponse) -- | The response's http status code. getJobRunResponse_httpStatus :: Lens.Lens' GetJobRunResponse Prelude.Int getJobRunResponse_httpStatus = Lens.lens (\GetJobRunResponse' {httpStatus} -> httpStatus) (\s@GetJobRunResponse' {} a -> s {httpStatus = a} :: GetJobRunResponse) instance Prelude.NFData GetJobRunResponse where rnf GetJobRunResponse' {..} = Prelude.rnf jobRun `Prelude.seq` Prelude.rnf httpStatus