{-# 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.Transfer.DescribeExecution -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- You can use @DescribeExecution@ to check the details of the execution of -- the specified workflow. module Amazonka.Transfer.DescribeExecution ( -- * Creating a Request DescribeExecution (..), newDescribeExecution, -- * Request Lenses describeExecution_executionId, describeExecution_workflowId, -- * Destructuring the Response DescribeExecutionResponse (..), newDescribeExecutionResponse, -- * Response Lenses describeExecutionResponse_httpStatus, describeExecutionResponse_workflowId, describeExecutionResponse_execution, ) 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.Transfer.Types -- | /See:/ 'newDescribeExecution' smart constructor. data DescribeExecution = DescribeExecution' { -- | A unique identifier for the execution of a workflow. executionId :: Prelude.Text, -- | A unique identifier for the workflow. workflowId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeExecution' 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: -- -- 'executionId', 'describeExecution_executionId' - A unique identifier for the execution of a workflow. -- -- 'workflowId', 'describeExecution_workflowId' - A unique identifier for the workflow. newDescribeExecution :: -- | 'executionId' Prelude.Text -> -- | 'workflowId' Prelude.Text -> DescribeExecution newDescribeExecution pExecutionId_ pWorkflowId_ = DescribeExecution' { executionId = pExecutionId_, workflowId = pWorkflowId_ } -- | A unique identifier for the execution of a workflow. describeExecution_executionId :: Lens.Lens' DescribeExecution Prelude.Text describeExecution_executionId = Lens.lens (\DescribeExecution' {executionId} -> executionId) (\s@DescribeExecution' {} a -> s {executionId = a} :: DescribeExecution) -- | A unique identifier for the workflow. describeExecution_workflowId :: Lens.Lens' DescribeExecution Prelude.Text describeExecution_workflowId = Lens.lens (\DescribeExecution' {workflowId} -> workflowId) (\s@DescribeExecution' {} a -> s {workflowId = a} :: DescribeExecution) instance Core.AWSRequest DescribeExecution where type AWSResponse DescribeExecution = DescribeExecutionResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DescribeExecutionResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) Prelude.<*> (x Data..:> "WorkflowId") Prelude.<*> (x Data..:> "Execution") ) instance Prelude.Hashable DescribeExecution where hashWithSalt _salt DescribeExecution' {..} = _salt `Prelude.hashWithSalt` executionId `Prelude.hashWithSalt` workflowId instance Prelude.NFData DescribeExecution where rnf DescribeExecution' {..} = Prelude.rnf executionId `Prelude.seq` Prelude.rnf workflowId instance Data.ToHeaders DescribeExecution where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "TransferService.DescribeExecution" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DescribeExecution where toJSON DescribeExecution' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("ExecutionId" Data..= executionId), Prelude.Just ("WorkflowId" Data..= workflowId) ] ) instance Data.ToPath DescribeExecution where toPath = Prelude.const "/" instance Data.ToQuery DescribeExecution where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDescribeExecutionResponse' smart constructor. data DescribeExecutionResponse = DescribeExecutionResponse' { -- | The response's http status code. httpStatus :: Prelude.Int, -- | A unique identifier for the workflow. workflowId :: Prelude.Text, -- | The structure that contains the details of the workflow\' execution. execution :: DescribedExecution } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeExecutionResponse' 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: -- -- 'httpStatus', 'describeExecutionResponse_httpStatus' - The response's http status code. -- -- 'workflowId', 'describeExecutionResponse_workflowId' - A unique identifier for the workflow. -- -- 'execution', 'describeExecutionResponse_execution' - The structure that contains the details of the workflow\' execution. newDescribeExecutionResponse :: -- | 'httpStatus' Prelude.Int -> -- | 'workflowId' Prelude.Text -> -- | 'execution' DescribedExecution -> DescribeExecutionResponse newDescribeExecutionResponse pHttpStatus_ pWorkflowId_ pExecution_ = DescribeExecutionResponse' { httpStatus = pHttpStatus_, workflowId = pWorkflowId_, execution = pExecution_ } -- | The response's http status code. describeExecutionResponse_httpStatus :: Lens.Lens' DescribeExecutionResponse Prelude.Int describeExecutionResponse_httpStatus = Lens.lens (\DescribeExecutionResponse' {httpStatus} -> httpStatus) (\s@DescribeExecutionResponse' {} a -> s {httpStatus = a} :: DescribeExecutionResponse) -- | A unique identifier for the workflow. describeExecutionResponse_workflowId :: Lens.Lens' DescribeExecutionResponse Prelude.Text describeExecutionResponse_workflowId = Lens.lens (\DescribeExecutionResponse' {workflowId} -> workflowId) (\s@DescribeExecutionResponse' {} a -> s {workflowId = a} :: DescribeExecutionResponse) -- | The structure that contains the details of the workflow\' execution. describeExecutionResponse_execution :: Lens.Lens' DescribeExecutionResponse DescribedExecution describeExecutionResponse_execution = Lens.lens (\DescribeExecutionResponse' {execution} -> execution) (\s@DescribeExecutionResponse' {} a -> s {execution = a} :: DescribeExecutionResponse) instance Prelude.NFData DescribeExecutionResponse where rnf DescribeExecutionResponse' {..} = Prelude.rnf httpStatus `Prelude.seq` Prelude.rnf workflowId `Prelude.seq` Prelude.rnf execution