{-# 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.UpdateApplication -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Changes the name of an application. module Amazonka.CodeDeploy.UpdateApplication ( -- * Creating a Request UpdateApplication (..), newUpdateApplication, -- * Request Lenses updateApplication_applicationName, updateApplication_newApplicationName, -- * Destructuring the Response UpdateApplicationResponse (..), newUpdateApplicationResponse, ) 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 an @UpdateApplication@ operation. -- -- /See:/ 'newUpdateApplication' smart constructor. data UpdateApplication = UpdateApplication' { -- | The current name of the application you want to change. applicationName :: Prelude.Maybe Prelude.Text, -- | The new name to give the application. newApplicationName' :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateApplication' 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: -- -- 'applicationName', 'updateApplication_applicationName' - The current name of the application you want to change. -- -- 'newApplicationName'', 'updateApplication_newApplicationName' - The new name to give the application. newUpdateApplication :: UpdateApplication newUpdateApplication = UpdateApplication' { applicationName = Prelude.Nothing, newApplicationName' = Prelude.Nothing } -- | The current name of the application you want to change. updateApplication_applicationName :: Lens.Lens' UpdateApplication (Prelude.Maybe Prelude.Text) updateApplication_applicationName = Lens.lens (\UpdateApplication' {applicationName} -> applicationName) (\s@UpdateApplication' {} a -> s {applicationName = a} :: UpdateApplication) -- | The new name to give the application. updateApplication_newApplicationName :: Lens.Lens' UpdateApplication (Prelude.Maybe Prelude.Text) updateApplication_newApplicationName = Lens.lens (\UpdateApplication' {newApplicationName'} -> newApplicationName') (\s@UpdateApplication' {} a -> s {newApplicationName' = a} :: UpdateApplication) instance Core.AWSRequest UpdateApplication where type AWSResponse UpdateApplication = UpdateApplicationResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveNull UpdateApplicationResponse' instance Prelude.Hashable UpdateApplication where hashWithSalt _salt UpdateApplication' {..} = _salt `Prelude.hashWithSalt` applicationName `Prelude.hashWithSalt` newApplicationName' instance Prelude.NFData UpdateApplication where rnf UpdateApplication' {..} = Prelude.rnf applicationName `Prelude.seq` Prelude.rnf newApplicationName' instance Data.ToHeaders UpdateApplication where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "CodeDeploy_20141006.UpdateApplication" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON UpdateApplication where toJSON UpdateApplication' {..} = Data.object ( Prelude.catMaybes [ ("applicationName" Data..=) Prelude.<$> applicationName, ("newApplicationName" Data..=) Prelude.<$> newApplicationName' ] ) instance Data.ToPath UpdateApplication where toPath = Prelude.const "/" instance Data.ToQuery UpdateApplication where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newUpdateApplicationResponse' smart constructor. data UpdateApplicationResponse = UpdateApplicationResponse' { } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateApplicationResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. newUpdateApplicationResponse :: UpdateApplicationResponse newUpdateApplicationResponse = UpdateApplicationResponse' instance Prelude.NFData UpdateApplicationResponse where rnf _ = ()