{-# 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.ECS.UpdateClusterSettings
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Modifies the settings to use for a cluster.
module Amazonka.ECS.UpdateClusterSettings
  ( -- * Creating a Request
    UpdateClusterSettings (..),
    newUpdateClusterSettings,

    -- * Request Lenses
    updateClusterSettings_cluster,
    updateClusterSettings_settings,

    -- * Destructuring the Response
    UpdateClusterSettingsResponse (..),
    newUpdateClusterSettingsResponse,

    -- * Response Lenses
    updateClusterSettingsResponse_cluster,
    updateClusterSettingsResponse_httpStatus,
  )
where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.ECS.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response

-- | /See:/ 'newUpdateClusterSettings' smart constructor.
data UpdateClusterSettings = UpdateClusterSettings'
  { -- | The name of the cluster to modify the settings for.
    UpdateClusterSettings -> Text
cluster :: Prelude.Text,
    -- | The setting to use by default for a cluster. This parameter is used to
    -- turn on CloudWatch Container Insights for a cluster. If this value is
    -- specified, it overrides the @containerInsights@ value set with
    -- PutAccountSetting or PutAccountSettingDefault.
    --
    -- Currently, if you delete an existing cluster that does not have
    -- Container Insights turned on, and then create a new cluster with the
    -- same name with Container Insights tuned on, Container Insights will not
    -- actually be turned on. If you want to preserve the same name for your
    -- existing cluster and turn on Container Insights, you must wait 7 days
    -- before you can re-create it.
    UpdateClusterSettings -> [ClusterSetting]
settings :: [ClusterSetting]
  }
  deriving (UpdateClusterSettings -> UpdateClusterSettings -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: UpdateClusterSettings -> UpdateClusterSettings -> Bool
$c/= :: UpdateClusterSettings -> UpdateClusterSettings -> Bool
== :: UpdateClusterSettings -> UpdateClusterSettings -> Bool
$c== :: UpdateClusterSettings -> UpdateClusterSettings -> Bool
Prelude.Eq, ReadPrec [UpdateClusterSettings]
ReadPrec UpdateClusterSettings
Int -> ReadS UpdateClusterSettings
ReadS [UpdateClusterSettings]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [UpdateClusterSettings]
$creadListPrec :: ReadPrec [UpdateClusterSettings]
readPrec :: ReadPrec UpdateClusterSettings
$creadPrec :: ReadPrec UpdateClusterSettings
readList :: ReadS [UpdateClusterSettings]
$creadList :: ReadS [UpdateClusterSettings]
readsPrec :: Int -> ReadS UpdateClusterSettings
$creadsPrec :: Int -> ReadS UpdateClusterSettings
Prelude.Read, Int -> UpdateClusterSettings -> ShowS
[UpdateClusterSettings] -> ShowS
UpdateClusterSettings -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [UpdateClusterSettings] -> ShowS
$cshowList :: [UpdateClusterSettings] -> ShowS
show :: UpdateClusterSettings -> String
$cshow :: UpdateClusterSettings -> String
showsPrec :: Int -> UpdateClusterSettings -> ShowS
$cshowsPrec :: Int -> UpdateClusterSettings -> ShowS
Prelude.Show, forall x. Rep UpdateClusterSettings x -> UpdateClusterSettings
forall x. UpdateClusterSettings -> Rep UpdateClusterSettings x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep UpdateClusterSettings x -> UpdateClusterSettings
$cfrom :: forall x. UpdateClusterSettings -> Rep UpdateClusterSettings x
Prelude.Generic)

-- |
-- Create a value of 'UpdateClusterSettings' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'cluster', 'updateClusterSettings_cluster' - The name of the cluster to modify the settings for.
--
-- 'settings', 'updateClusterSettings_settings' - The setting to use by default for a cluster. This parameter is used to
-- turn on CloudWatch Container Insights for a cluster. If this value is
-- specified, it overrides the @containerInsights@ value set with
-- PutAccountSetting or PutAccountSettingDefault.
--
-- Currently, if you delete an existing cluster that does not have
-- Container Insights turned on, and then create a new cluster with the
-- same name with Container Insights tuned on, Container Insights will not
-- actually be turned on. If you want to preserve the same name for your
-- existing cluster and turn on Container Insights, you must wait 7 days
-- before you can re-create it.
newUpdateClusterSettings ::
  -- | 'cluster'
  Prelude.Text ->
  UpdateClusterSettings
newUpdateClusterSettings :: Text -> UpdateClusterSettings
newUpdateClusterSettings Text
pCluster_ =
  UpdateClusterSettings'
    { $sel:cluster:UpdateClusterSettings' :: Text
cluster = Text
pCluster_,
      $sel:settings:UpdateClusterSettings' :: [ClusterSetting]
settings = forall a. Monoid a => a
Prelude.mempty
    }

-- | The name of the cluster to modify the settings for.
updateClusterSettings_cluster :: Lens.Lens' UpdateClusterSettings Prelude.Text
updateClusterSettings_cluster :: Lens' UpdateClusterSettings Text
updateClusterSettings_cluster = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateClusterSettings' {Text
cluster :: Text
$sel:cluster:UpdateClusterSettings' :: UpdateClusterSettings -> Text
cluster} -> Text
cluster) (\s :: UpdateClusterSettings
s@UpdateClusterSettings' {} Text
a -> UpdateClusterSettings
s {$sel:cluster:UpdateClusterSettings' :: Text
cluster = Text
a} :: UpdateClusterSettings)

-- | The setting to use by default for a cluster. This parameter is used to
-- turn on CloudWatch Container Insights for a cluster. If this value is
-- specified, it overrides the @containerInsights@ value set with
-- PutAccountSetting or PutAccountSettingDefault.
--
-- Currently, if you delete an existing cluster that does not have
-- Container Insights turned on, and then create a new cluster with the
-- same name with Container Insights tuned on, Container Insights will not
-- actually be turned on. If you want to preserve the same name for your
-- existing cluster and turn on Container Insights, you must wait 7 days
-- before you can re-create it.
updateClusterSettings_settings :: Lens.Lens' UpdateClusterSettings [ClusterSetting]
updateClusterSettings_settings :: Lens' UpdateClusterSettings [ClusterSetting]
updateClusterSettings_settings = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateClusterSettings' {[ClusterSetting]
settings :: [ClusterSetting]
$sel:settings:UpdateClusterSettings' :: UpdateClusterSettings -> [ClusterSetting]
settings} -> [ClusterSetting]
settings) (\s :: UpdateClusterSettings
s@UpdateClusterSettings' {} [ClusterSetting]
a -> UpdateClusterSettings
s {$sel:settings:UpdateClusterSettings' :: [ClusterSetting]
settings = [ClusterSetting]
a} :: UpdateClusterSettings) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

instance Core.AWSRequest UpdateClusterSettings where
  type
    AWSResponse UpdateClusterSettings =
      UpdateClusterSettingsResponse
  request :: (Service -> Service)
-> UpdateClusterSettings -> Request UpdateClusterSettings
request Service -> Service
overrides =
    forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.postJSON (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy UpdateClusterSettings
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse UpdateClusterSettings)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> Object -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveJSON
      ( \Int
s ResponseHeaders
h Object
x ->
          Maybe Cluster -> Int -> UpdateClusterSettingsResponse
UpdateClusterSettingsResponse'
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"cluster")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure (forall a. Enum a => a -> Int
Prelude.fromEnum Int
s))
      )

instance Prelude.Hashable UpdateClusterSettings where
  hashWithSalt :: Int -> UpdateClusterSettings -> Int
hashWithSalt Int
_salt UpdateClusterSettings' {[ClusterSetting]
Text
settings :: [ClusterSetting]
cluster :: Text
$sel:settings:UpdateClusterSettings' :: UpdateClusterSettings -> [ClusterSetting]
$sel:cluster:UpdateClusterSettings' :: UpdateClusterSettings -> Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
cluster
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` [ClusterSetting]
settings

instance Prelude.NFData UpdateClusterSettings where
  rnf :: UpdateClusterSettings -> ()
rnf UpdateClusterSettings' {[ClusterSetting]
Text
settings :: [ClusterSetting]
cluster :: Text
$sel:settings:UpdateClusterSettings' :: UpdateClusterSettings -> [ClusterSetting]
$sel:cluster:UpdateClusterSettings' :: UpdateClusterSettings -> Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Text
cluster
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf [ClusterSetting]
settings

instance Data.ToHeaders UpdateClusterSettings where
  toHeaders :: UpdateClusterSettings -> ResponseHeaders
toHeaders =
    forall a b. a -> b -> a
Prelude.const
      ( forall a. Monoid a => [a] -> a
Prelude.mconcat
          [ HeaderName
"X-Amz-Target"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"AmazonEC2ContainerServiceV20141113.UpdateClusterSettings" ::
                          Prelude.ByteString
                      ),
            HeaderName
"Content-Type"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
                          Prelude.ByteString
                      )
          ]
      )

instance Data.ToJSON UpdateClusterSettings where
  toJSON :: UpdateClusterSettings -> Value
toJSON UpdateClusterSettings' {[ClusterSetting]
Text
settings :: [ClusterSetting]
cluster :: Text
$sel:settings:UpdateClusterSettings' :: UpdateClusterSettings -> [ClusterSetting]
$sel:cluster:UpdateClusterSettings' :: UpdateClusterSettings -> Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ forall a. a -> Maybe a
Prelude.Just (Key
"cluster" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
cluster),
            forall a. a -> Maybe a
Prelude.Just (Key
"settings" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= [ClusterSetting]
settings)
          ]
      )

instance Data.ToPath UpdateClusterSettings where
  toPath :: UpdateClusterSettings -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"

instance Data.ToQuery UpdateClusterSettings where
  toQuery :: UpdateClusterSettings -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

-- | /See:/ 'newUpdateClusterSettingsResponse' smart constructor.
data UpdateClusterSettingsResponse = UpdateClusterSettingsResponse'
  { -- | Details about the cluster
    UpdateClusterSettingsResponse -> Maybe Cluster
cluster :: Prelude.Maybe Cluster,
    -- | The response's http status code.
    UpdateClusterSettingsResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (UpdateClusterSettingsResponse
-> UpdateClusterSettingsResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: UpdateClusterSettingsResponse
-> UpdateClusterSettingsResponse -> Bool
$c/= :: UpdateClusterSettingsResponse
-> UpdateClusterSettingsResponse -> Bool
== :: UpdateClusterSettingsResponse
-> UpdateClusterSettingsResponse -> Bool
$c== :: UpdateClusterSettingsResponse
-> UpdateClusterSettingsResponse -> Bool
Prelude.Eq, ReadPrec [UpdateClusterSettingsResponse]
ReadPrec UpdateClusterSettingsResponse
Int -> ReadS UpdateClusterSettingsResponse
ReadS [UpdateClusterSettingsResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [UpdateClusterSettingsResponse]
$creadListPrec :: ReadPrec [UpdateClusterSettingsResponse]
readPrec :: ReadPrec UpdateClusterSettingsResponse
$creadPrec :: ReadPrec UpdateClusterSettingsResponse
readList :: ReadS [UpdateClusterSettingsResponse]
$creadList :: ReadS [UpdateClusterSettingsResponse]
readsPrec :: Int -> ReadS UpdateClusterSettingsResponse
$creadsPrec :: Int -> ReadS UpdateClusterSettingsResponse
Prelude.Read, Int -> UpdateClusterSettingsResponse -> ShowS
[UpdateClusterSettingsResponse] -> ShowS
UpdateClusterSettingsResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [UpdateClusterSettingsResponse] -> ShowS
$cshowList :: [UpdateClusterSettingsResponse] -> ShowS
show :: UpdateClusterSettingsResponse -> String
$cshow :: UpdateClusterSettingsResponse -> String
showsPrec :: Int -> UpdateClusterSettingsResponse -> ShowS
$cshowsPrec :: Int -> UpdateClusterSettingsResponse -> ShowS
Prelude.Show, forall x.
Rep UpdateClusterSettingsResponse x
-> UpdateClusterSettingsResponse
forall x.
UpdateClusterSettingsResponse
-> Rep UpdateClusterSettingsResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep UpdateClusterSettingsResponse x
-> UpdateClusterSettingsResponse
$cfrom :: forall x.
UpdateClusterSettingsResponse
-> Rep UpdateClusterSettingsResponse x
Prelude.Generic)

-- |
-- Create a value of 'UpdateClusterSettingsResponse' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'cluster', 'updateClusterSettingsResponse_cluster' - Details about the cluster
--
-- 'httpStatus', 'updateClusterSettingsResponse_httpStatus' - The response's http status code.
newUpdateClusterSettingsResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  UpdateClusterSettingsResponse
newUpdateClusterSettingsResponse :: Int -> UpdateClusterSettingsResponse
newUpdateClusterSettingsResponse Int
pHttpStatus_ =
  UpdateClusterSettingsResponse'
    { $sel:cluster:UpdateClusterSettingsResponse' :: Maybe Cluster
cluster =
        forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:UpdateClusterSettingsResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | Details about the cluster
updateClusterSettingsResponse_cluster :: Lens.Lens' UpdateClusterSettingsResponse (Prelude.Maybe Cluster)
updateClusterSettingsResponse_cluster :: Lens' UpdateClusterSettingsResponse (Maybe Cluster)
updateClusterSettingsResponse_cluster = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateClusterSettingsResponse' {Maybe Cluster
cluster :: Maybe Cluster
$sel:cluster:UpdateClusterSettingsResponse' :: UpdateClusterSettingsResponse -> Maybe Cluster
cluster} -> Maybe Cluster
cluster) (\s :: UpdateClusterSettingsResponse
s@UpdateClusterSettingsResponse' {} Maybe Cluster
a -> UpdateClusterSettingsResponse
s {$sel:cluster:UpdateClusterSettingsResponse' :: Maybe Cluster
cluster = Maybe Cluster
a} :: UpdateClusterSettingsResponse)

-- | The response's http status code.
updateClusterSettingsResponse_httpStatus :: Lens.Lens' UpdateClusterSettingsResponse Prelude.Int
updateClusterSettingsResponse_httpStatus :: Lens' UpdateClusterSettingsResponse Int
updateClusterSettingsResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateClusterSettingsResponse' {Int
httpStatus :: Int
$sel:httpStatus:UpdateClusterSettingsResponse' :: UpdateClusterSettingsResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: UpdateClusterSettingsResponse
s@UpdateClusterSettingsResponse' {} Int
a -> UpdateClusterSettingsResponse
s {$sel:httpStatus:UpdateClusterSettingsResponse' :: Int
httpStatus = Int
a} :: UpdateClusterSettingsResponse)

instance Prelude.NFData UpdateClusterSettingsResponse where
  rnf :: UpdateClusterSettingsResponse -> ()
rnf UpdateClusterSettingsResponse' {Int
Maybe Cluster
httpStatus :: Int
cluster :: Maybe Cluster
$sel:httpStatus:UpdateClusterSettingsResponse' :: UpdateClusterSettingsResponse -> Int
$sel:cluster:UpdateClusterSettingsResponse' :: UpdateClusterSettingsResponse -> Maybe Cluster
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Cluster
cluster
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus