{-# 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.DataPipeline.DeactivatePipeline -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Deactivates the specified running pipeline. The pipeline is set to the -- @DEACTIVATING@ state until the deactivation process completes. -- -- To resume a deactivated pipeline, use ActivatePipeline. By default, the -- pipeline resumes from the last completed execution. Optionally, you can -- specify the date and time to resume the pipeline. module Amazonka.DataPipeline.DeactivatePipeline ( -- * Creating a Request DeactivatePipeline (..), newDeactivatePipeline, -- * Request Lenses deactivatePipeline_cancelActive, deactivatePipeline_pipelineId, -- * Destructuring the Response DeactivatePipelineResponse (..), newDeactivatePipelineResponse, -- * Response Lenses deactivatePipelineResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.DataPipeline.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | Contains the parameters for DeactivatePipeline. -- -- /See:/ 'newDeactivatePipeline' smart constructor. data DeactivatePipeline = DeactivatePipeline' { -- | Indicates whether to cancel any running objects. The default is true, -- which sets the state of any running objects to @CANCELED@. If this value -- is false, the pipeline is deactivated after all running objects finish. cancelActive :: Prelude.Maybe Prelude.Bool, -- | The ID of the pipeline. pipelineId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeactivatePipeline' 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: -- -- 'cancelActive', 'deactivatePipeline_cancelActive' - Indicates whether to cancel any running objects. The default is true, -- which sets the state of any running objects to @CANCELED@. If this value -- is false, the pipeline is deactivated after all running objects finish. -- -- 'pipelineId', 'deactivatePipeline_pipelineId' - The ID of the pipeline. newDeactivatePipeline :: -- | 'pipelineId' Prelude.Text -> DeactivatePipeline newDeactivatePipeline pPipelineId_ = DeactivatePipeline' { cancelActive = Prelude.Nothing, pipelineId = pPipelineId_ } -- | Indicates whether to cancel any running objects. The default is true, -- which sets the state of any running objects to @CANCELED@. If this value -- is false, the pipeline is deactivated after all running objects finish. deactivatePipeline_cancelActive :: Lens.Lens' DeactivatePipeline (Prelude.Maybe Prelude.Bool) deactivatePipeline_cancelActive = Lens.lens (\DeactivatePipeline' {cancelActive} -> cancelActive) (\s@DeactivatePipeline' {} a -> s {cancelActive = a} :: DeactivatePipeline) -- | The ID of the pipeline. deactivatePipeline_pipelineId :: Lens.Lens' DeactivatePipeline Prelude.Text deactivatePipeline_pipelineId = Lens.lens (\DeactivatePipeline' {pipelineId} -> pipelineId) (\s@DeactivatePipeline' {} a -> s {pipelineId = a} :: DeactivatePipeline) instance Core.AWSRequest DeactivatePipeline where type AWSResponse DeactivatePipeline = DeactivatePipelineResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveEmpty ( \s h x -> DeactivatePipelineResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeactivatePipeline where hashWithSalt _salt DeactivatePipeline' {..} = _salt `Prelude.hashWithSalt` cancelActive `Prelude.hashWithSalt` pipelineId instance Prelude.NFData DeactivatePipeline where rnf DeactivatePipeline' {..} = Prelude.rnf cancelActive `Prelude.seq` Prelude.rnf pipelineId instance Data.ToHeaders DeactivatePipeline where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "DataPipeline.DeactivatePipeline" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DeactivatePipeline where toJSON DeactivatePipeline' {..} = Data.object ( Prelude.catMaybes [ ("cancelActive" Data..=) Prelude.<$> cancelActive, Prelude.Just ("pipelineId" Data..= pipelineId) ] ) instance Data.ToPath DeactivatePipeline where toPath = Prelude.const "/" instance Data.ToQuery DeactivatePipeline where toQuery = Prelude.const Prelude.mempty -- | Contains the output of DeactivatePipeline. -- -- /See:/ 'newDeactivatePipelineResponse' smart constructor. data DeactivatePipelineResponse = DeactivatePipelineResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeactivatePipelineResponse' 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', 'deactivatePipelineResponse_httpStatus' - The response's http status code. newDeactivatePipelineResponse :: -- | 'httpStatus' Prelude.Int -> DeactivatePipelineResponse newDeactivatePipelineResponse pHttpStatus_ = DeactivatePipelineResponse' { httpStatus = pHttpStatus_ } -- | The response's http status code. deactivatePipelineResponse_httpStatus :: Lens.Lens' DeactivatePipelineResponse Prelude.Int deactivatePipelineResponse_httpStatus = Lens.lens (\DeactivatePipelineResponse' {httpStatus} -> httpStatus) (\s@DeactivatePipelineResponse' {} a -> s {httpStatus = a} :: DeactivatePipelineResponse) instance Prelude.NFData DeactivatePipelineResponse where rnf DeactivatePipelineResponse' {..} = Prelude.rnf httpStatus