{-# 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.CodeDeploy.StopDeployment -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Attempts to stop an ongoing deployment. module Amazonka.CodeDeploy.StopDeployment ( -- * Creating a Request StopDeployment (..), newStopDeployment, -- * Request Lenses stopDeployment_autoRollbackEnabled, stopDeployment_deploymentId, -- * Destructuring the Response StopDeploymentResponse (..), newStopDeploymentResponse, -- * Response Lenses stopDeploymentResponse_status, stopDeploymentResponse_statusMessage, stopDeploymentResponse_httpStatus, ) where import Amazonka.CodeDeploy.Types 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 -- | Represents the input of a @StopDeployment@ operation. -- -- /See:/ 'newStopDeployment' smart constructor. data StopDeployment = StopDeployment' { -- | Indicates, when a deployment is stopped, whether instances that have -- been updated should be rolled back to the previous version of the -- application revision. autoRollbackEnabled :: Prelude.Maybe Prelude.Bool, -- | The unique ID of a deployment. deploymentId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'StopDeployment' 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: -- -- 'autoRollbackEnabled', 'stopDeployment_autoRollbackEnabled' - Indicates, when a deployment is stopped, whether instances that have -- been updated should be rolled back to the previous version of the -- application revision. -- -- 'deploymentId', 'stopDeployment_deploymentId' - The unique ID of a deployment. newStopDeployment :: -- | 'deploymentId' Prelude.Text -> StopDeployment newStopDeployment pDeploymentId_ = StopDeployment' { autoRollbackEnabled = Prelude.Nothing, deploymentId = pDeploymentId_ } -- | Indicates, when a deployment is stopped, whether instances that have -- been updated should be rolled back to the previous version of the -- application revision. stopDeployment_autoRollbackEnabled :: Lens.Lens' StopDeployment (Prelude.Maybe Prelude.Bool) stopDeployment_autoRollbackEnabled = Lens.lens (\StopDeployment' {autoRollbackEnabled} -> autoRollbackEnabled) (\s@StopDeployment' {} a -> s {autoRollbackEnabled = a} :: StopDeployment) -- | The unique ID of a deployment. stopDeployment_deploymentId :: Lens.Lens' StopDeployment Prelude.Text stopDeployment_deploymentId = Lens.lens (\StopDeployment' {deploymentId} -> deploymentId) (\s@StopDeployment' {} a -> s {deploymentId = a} :: StopDeployment) instance Core.AWSRequest StopDeployment where type AWSResponse StopDeployment = StopDeploymentResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> StopDeploymentResponse' Prelude.<$> (x Data..?> "status") Prelude.<*> (x Data..?> "statusMessage") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable StopDeployment where hashWithSalt _salt StopDeployment' {..} = _salt `Prelude.hashWithSalt` autoRollbackEnabled `Prelude.hashWithSalt` deploymentId instance Prelude.NFData StopDeployment where rnf StopDeployment' {..} = Prelude.rnf autoRollbackEnabled `Prelude.seq` Prelude.rnf deploymentId instance Data.ToHeaders StopDeployment where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "CodeDeploy_20141006.StopDeployment" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON StopDeployment where toJSON StopDeployment' {..} = Data.object ( Prelude.catMaybes [ ("autoRollbackEnabled" Data..=) Prelude.<$> autoRollbackEnabled, Prelude.Just ("deploymentId" Data..= deploymentId) ] ) instance Data.ToPath StopDeployment where toPath = Prelude.const "/" instance Data.ToQuery StopDeployment where toQuery = Prelude.const Prelude.mempty -- | Represents the output of a @StopDeployment@ operation. -- -- /See:/ 'newStopDeploymentResponse' smart constructor. data StopDeploymentResponse = StopDeploymentResponse' { -- | The status of the stop deployment operation: -- -- - Pending: The stop operation is pending. -- -- - Succeeded: The stop operation was successful. status :: Prelude.Maybe StopStatus, -- | An accompanying status message. statusMessage :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'StopDeploymentResponse' 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: -- -- 'status', 'stopDeploymentResponse_status' - The status of the stop deployment operation: -- -- - Pending: The stop operation is pending. -- -- - Succeeded: The stop operation was successful. -- -- 'statusMessage', 'stopDeploymentResponse_statusMessage' - An accompanying status message. -- -- 'httpStatus', 'stopDeploymentResponse_httpStatus' - The response's http status code. newStopDeploymentResponse :: -- | 'httpStatus' Prelude.Int -> StopDeploymentResponse newStopDeploymentResponse pHttpStatus_ = StopDeploymentResponse' { status = Prelude.Nothing, statusMessage = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The status of the stop deployment operation: -- -- - Pending: The stop operation is pending. -- -- - Succeeded: The stop operation was successful. stopDeploymentResponse_status :: Lens.Lens' StopDeploymentResponse (Prelude.Maybe StopStatus) stopDeploymentResponse_status = Lens.lens (\StopDeploymentResponse' {status} -> status) (\s@StopDeploymentResponse' {} a -> s {status = a} :: StopDeploymentResponse) -- | An accompanying status message. stopDeploymentResponse_statusMessage :: Lens.Lens' StopDeploymentResponse (Prelude.Maybe Prelude.Text) stopDeploymentResponse_statusMessage = Lens.lens (\StopDeploymentResponse' {statusMessage} -> statusMessage) (\s@StopDeploymentResponse' {} a -> s {statusMessage = a} :: StopDeploymentResponse) -- | The response's http status code. stopDeploymentResponse_httpStatus :: Lens.Lens' StopDeploymentResponse Prelude.Int stopDeploymentResponse_httpStatus = Lens.lens (\StopDeploymentResponse' {httpStatus} -> httpStatus) (\s@StopDeploymentResponse' {} a -> s {httpStatus = a} :: StopDeploymentResponse) instance Prelude.NFData StopDeploymentResponse where rnf StopDeploymentResponse' {..} = Prelude.rnf status `Prelude.seq` Prelude.rnf statusMessage `Prelude.seq` Prelude.rnf httpStatus