{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE NamedFieldPuns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE NoImplicitPrelude #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Amazonka.EMR.Types.NotebookExecutionSummary -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) module Amazonka.EMR.Types.NotebookExecutionSummary where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.EMR.Types.NotebookExecutionStatus import qualified Amazonka.Prelude as Prelude -- | Details for a notebook execution. The details include information such -- as the unique ID and status of the notebook execution. -- -- /See:/ 'newNotebookExecutionSummary' smart constructor. data NotebookExecutionSummary = NotebookExecutionSummary' { -- | The unique identifier of the editor associated with the notebook -- execution. editorId :: Prelude.Maybe Prelude.Text, -- | The timestamp when notebook execution started. endTime :: Prelude.Maybe Data.POSIX, -- | The unique identifier of the notebook execution. notebookExecutionId :: Prelude.Maybe Prelude.Text, -- | The name of the notebook execution. notebookExecutionName :: Prelude.Maybe Prelude.Text, -- | The timestamp when notebook execution started. startTime :: Prelude.Maybe Data.POSIX, -- | The status of the notebook execution. -- -- - @START_PENDING@ indicates that the cluster has received the -- execution request but execution has not begun. -- -- - @STARTING@ indicates that the execution is starting on the cluster. -- -- - @RUNNING@ indicates that the execution is being processed by the -- cluster. -- -- - @FINISHING@ indicates that execution processing is in the final -- stages. -- -- - @FINISHED@ indicates that the execution has completed without error. -- -- - @FAILING@ indicates that the execution is failing and will not -- finish successfully. -- -- - @FAILED@ indicates that the execution failed. -- -- - @STOP_PENDING@ indicates that the cluster has received a -- @StopNotebookExecution@ request and the stop is pending. -- -- - @STOPPING@ indicates that the cluster is in the process of stopping -- the execution as a result of a @StopNotebookExecution@ request. -- -- - @STOPPED@ indicates that the execution stopped because of a -- @StopNotebookExecution@ request. status :: Prelude.Maybe NotebookExecutionStatus } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'NotebookExecutionSummary' 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: -- -- 'editorId', 'notebookExecutionSummary_editorId' - The unique identifier of the editor associated with the notebook -- execution. -- -- 'endTime', 'notebookExecutionSummary_endTime' - The timestamp when notebook execution started. -- -- 'notebookExecutionId', 'notebookExecutionSummary_notebookExecutionId' - The unique identifier of the notebook execution. -- -- 'notebookExecutionName', 'notebookExecutionSummary_notebookExecutionName' - The name of the notebook execution. -- -- 'startTime', 'notebookExecutionSummary_startTime' - The timestamp when notebook execution started. -- -- 'status', 'notebookExecutionSummary_status' - The status of the notebook execution. -- -- - @START_PENDING@ indicates that the cluster has received the -- execution request but execution has not begun. -- -- - @STARTING@ indicates that the execution is starting on the cluster. -- -- - @RUNNING@ indicates that the execution is being processed by the -- cluster. -- -- - @FINISHING@ indicates that execution processing is in the final -- stages. -- -- - @FINISHED@ indicates that the execution has completed without error. -- -- - @FAILING@ indicates that the execution is failing and will not -- finish successfully. -- -- - @FAILED@ indicates that the execution failed. -- -- - @STOP_PENDING@ indicates that the cluster has received a -- @StopNotebookExecution@ request and the stop is pending. -- -- - @STOPPING@ indicates that the cluster is in the process of stopping -- the execution as a result of a @StopNotebookExecution@ request. -- -- - @STOPPED@ indicates that the execution stopped because of a -- @StopNotebookExecution@ request. newNotebookExecutionSummary :: NotebookExecutionSummary newNotebookExecutionSummary = NotebookExecutionSummary' { editorId = Prelude.Nothing, endTime = Prelude.Nothing, notebookExecutionId = Prelude.Nothing, notebookExecutionName = Prelude.Nothing, startTime = Prelude.Nothing, status = Prelude.Nothing } -- | The unique identifier of the editor associated with the notebook -- execution. notebookExecutionSummary_editorId :: Lens.Lens' NotebookExecutionSummary (Prelude.Maybe Prelude.Text) notebookExecutionSummary_editorId = Lens.lens (\NotebookExecutionSummary' {editorId} -> editorId) (\s@NotebookExecutionSummary' {} a -> s {editorId = a} :: NotebookExecutionSummary) -- | The timestamp when notebook execution started. notebookExecutionSummary_endTime :: Lens.Lens' NotebookExecutionSummary (Prelude.Maybe Prelude.UTCTime) notebookExecutionSummary_endTime = Lens.lens (\NotebookExecutionSummary' {endTime} -> endTime) (\s@NotebookExecutionSummary' {} a -> s {endTime = a} :: NotebookExecutionSummary) Prelude.. Lens.mapping Data._Time -- | The unique identifier of the notebook execution. notebookExecutionSummary_notebookExecutionId :: Lens.Lens' NotebookExecutionSummary (Prelude.Maybe Prelude.Text) notebookExecutionSummary_notebookExecutionId = Lens.lens (\NotebookExecutionSummary' {notebookExecutionId} -> notebookExecutionId) (\s@NotebookExecutionSummary' {} a -> s {notebookExecutionId = a} :: NotebookExecutionSummary) -- | The name of the notebook execution. notebookExecutionSummary_notebookExecutionName :: Lens.Lens' NotebookExecutionSummary (Prelude.Maybe Prelude.Text) notebookExecutionSummary_notebookExecutionName = Lens.lens (\NotebookExecutionSummary' {notebookExecutionName} -> notebookExecutionName) (\s@NotebookExecutionSummary' {} a -> s {notebookExecutionName = a} :: NotebookExecutionSummary) -- | The timestamp when notebook execution started. notebookExecutionSummary_startTime :: Lens.Lens' NotebookExecutionSummary (Prelude.Maybe Prelude.UTCTime) notebookExecutionSummary_startTime = Lens.lens (\NotebookExecutionSummary' {startTime} -> startTime) (\s@NotebookExecutionSummary' {} a -> s {startTime = a} :: NotebookExecutionSummary) Prelude.. Lens.mapping Data._Time -- | The status of the notebook execution. -- -- - @START_PENDING@ indicates that the cluster has received the -- execution request but execution has not begun. -- -- - @STARTING@ indicates that the execution is starting on the cluster. -- -- - @RUNNING@ indicates that the execution is being processed by the -- cluster. -- -- - @FINISHING@ indicates that execution processing is in the final -- stages. -- -- - @FINISHED@ indicates that the execution has completed without error. -- -- - @FAILING@ indicates that the execution is failing and will not -- finish successfully. -- -- - @FAILED@ indicates that the execution failed. -- -- - @STOP_PENDING@ indicates that the cluster has received a -- @StopNotebookExecution@ request and the stop is pending. -- -- - @STOPPING@ indicates that the cluster is in the process of stopping -- the execution as a result of a @StopNotebookExecution@ request. -- -- - @STOPPED@ indicates that the execution stopped because of a -- @StopNotebookExecution@ request. notebookExecutionSummary_status :: Lens.Lens' NotebookExecutionSummary (Prelude.Maybe NotebookExecutionStatus) notebookExecutionSummary_status = Lens.lens (\NotebookExecutionSummary' {status} -> status) (\s@NotebookExecutionSummary' {} a -> s {status = a} :: NotebookExecutionSummary) instance Data.FromJSON NotebookExecutionSummary where parseJSON = Data.withObject "NotebookExecutionSummary" ( \x -> NotebookExecutionSummary' Prelude.<$> (x Data..:? "EditorId") Prelude.<*> (x Data..:? "EndTime") Prelude.<*> (x Data..:? "NotebookExecutionId") Prelude.<*> (x Data..:? "NotebookExecutionName") Prelude.<*> (x Data..:? "StartTime") Prelude.<*> (x Data..:? "Status") ) instance Prelude.Hashable NotebookExecutionSummary where hashWithSalt _salt NotebookExecutionSummary' {..} = _salt `Prelude.hashWithSalt` editorId `Prelude.hashWithSalt` endTime `Prelude.hashWithSalt` notebookExecutionId `Prelude.hashWithSalt` notebookExecutionName `Prelude.hashWithSalt` startTime `Prelude.hashWithSalt` status instance Prelude.NFData NotebookExecutionSummary where rnf NotebookExecutionSummary' {..} = Prelude.rnf editorId `Prelude.seq` Prelude.rnf endTime `Prelude.seq` Prelude.rnf notebookExecutionId `Prelude.seq` Prelude.rnf notebookExecutionName `Prelude.seq` Prelude.rnf startTime `Prelude.seq` Prelude.rnf status