{-# 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.AutoScaling.DetachLoadBalancers
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Detaches one or more Classic Load Balancers from the specified Auto
-- Scaling group.
--
-- This operation detaches only Classic Load Balancers. If you have
-- Application Load Balancers, Network Load Balancers, or Gateway Load
-- Balancer, use the DetachLoadBalancerTargetGroups API instead.
--
-- When you detach a load balancer, it enters the @Removing@ state while
-- deregistering the instances in the group. When all instances are
-- deregistered, then you can no longer describe the load balancer using
-- the DescribeLoadBalancers API call. The instances remain running.
module Amazonka.AutoScaling.DetachLoadBalancers
  ( -- * Creating a Request
    DetachLoadBalancers (..),
    newDetachLoadBalancers,

    -- * Request Lenses
    detachLoadBalancers_autoScalingGroupName,
    detachLoadBalancers_loadBalancerNames,

    -- * Destructuring the Response
    DetachLoadBalancersResponse (..),
    newDetachLoadBalancersResponse,

    -- * Response Lenses
    detachLoadBalancersResponse_httpStatus,
  )
where

import Amazonka.AutoScaling.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

-- | /See:/ 'newDetachLoadBalancers' smart constructor.
data DetachLoadBalancers = DetachLoadBalancers'
  { -- | The name of the Auto Scaling group.
    DetachLoadBalancers -> Text
autoScalingGroupName :: Prelude.Text,
    -- | The names of the load balancers. You can specify up to 10 load
    -- balancers.
    DetachLoadBalancers -> [Text]
loadBalancerNames :: [Prelude.Text]
  }
  deriving (DetachLoadBalancers -> DetachLoadBalancers -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DetachLoadBalancers -> DetachLoadBalancers -> Bool
$c/= :: DetachLoadBalancers -> DetachLoadBalancers -> Bool
== :: DetachLoadBalancers -> DetachLoadBalancers -> Bool
$c== :: DetachLoadBalancers -> DetachLoadBalancers -> Bool
Prelude.Eq, ReadPrec [DetachLoadBalancers]
ReadPrec DetachLoadBalancers
Int -> ReadS DetachLoadBalancers
ReadS [DetachLoadBalancers]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DetachLoadBalancers]
$creadListPrec :: ReadPrec [DetachLoadBalancers]
readPrec :: ReadPrec DetachLoadBalancers
$creadPrec :: ReadPrec DetachLoadBalancers
readList :: ReadS [DetachLoadBalancers]
$creadList :: ReadS [DetachLoadBalancers]
readsPrec :: Int -> ReadS DetachLoadBalancers
$creadsPrec :: Int -> ReadS DetachLoadBalancers
Prelude.Read, Int -> DetachLoadBalancers -> ShowS
[DetachLoadBalancers] -> ShowS
DetachLoadBalancers -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DetachLoadBalancers] -> ShowS
$cshowList :: [DetachLoadBalancers] -> ShowS
show :: DetachLoadBalancers -> String
$cshow :: DetachLoadBalancers -> String
showsPrec :: Int -> DetachLoadBalancers -> ShowS
$cshowsPrec :: Int -> DetachLoadBalancers -> ShowS
Prelude.Show, forall x. Rep DetachLoadBalancers x -> DetachLoadBalancers
forall x. DetachLoadBalancers -> Rep DetachLoadBalancers x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DetachLoadBalancers x -> DetachLoadBalancers
$cfrom :: forall x. DetachLoadBalancers -> Rep DetachLoadBalancers x
Prelude.Generic)

-- |
-- Create a value of 'DetachLoadBalancers' 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:
--
-- 'autoScalingGroupName', 'detachLoadBalancers_autoScalingGroupName' - The name of the Auto Scaling group.
--
-- 'loadBalancerNames', 'detachLoadBalancers_loadBalancerNames' - The names of the load balancers. You can specify up to 10 load
-- balancers.
newDetachLoadBalancers ::
  -- | 'autoScalingGroupName'
  Prelude.Text ->
  DetachLoadBalancers
newDetachLoadBalancers :: Text -> DetachLoadBalancers
newDetachLoadBalancers Text
pAutoScalingGroupName_ =
  DetachLoadBalancers'
    { $sel:autoScalingGroupName:DetachLoadBalancers' :: Text
autoScalingGroupName =
        Text
pAutoScalingGroupName_,
      $sel:loadBalancerNames:DetachLoadBalancers' :: [Text]
loadBalancerNames = forall a. Monoid a => a
Prelude.mempty
    }

-- | The name of the Auto Scaling group.
detachLoadBalancers_autoScalingGroupName :: Lens.Lens' DetachLoadBalancers Prelude.Text
detachLoadBalancers_autoScalingGroupName :: Lens' DetachLoadBalancers Text
detachLoadBalancers_autoScalingGroupName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DetachLoadBalancers' {Text
autoScalingGroupName :: Text
$sel:autoScalingGroupName:DetachLoadBalancers' :: DetachLoadBalancers -> Text
autoScalingGroupName} -> Text
autoScalingGroupName) (\s :: DetachLoadBalancers
s@DetachLoadBalancers' {} Text
a -> DetachLoadBalancers
s {$sel:autoScalingGroupName:DetachLoadBalancers' :: Text
autoScalingGroupName = Text
a} :: DetachLoadBalancers)

-- | The names of the load balancers. You can specify up to 10 load
-- balancers.
detachLoadBalancers_loadBalancerNames :: Lens.Lens' DetachLoadBalancers [Prelude.Text]
detachLoadBalancers_loadBalancerNames :: Lens' DetachLoadBalancers [Text]
detachLoadBalancers_loadBalancerNames = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DetachLoadBalancers' {[Text]
loadBalancerNames :: [Text]
$sel:loadBalancerNames:DetachLoadBalancers' :: DetachLoadBalancers -> [Text]
loadBalancerNames} -> [Text]
loadBalancerNames) (\s :: DetachLoadBalancers
s@DetachLoadBalancers' {} [Text]
a -> DetachLoadBalancers
s {$sel:loadBalancerNames:DetachLoadBalancers' :: [Text]
loadBalancerNames = [Text]
a} :: DetachLoadBalancers) 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 DetachLoadBalancers where
  type
    AWSResponse DetachLoadBalancers =
      DetachLoadBalancersResponse
  request :: (Service -> Service)
-> DetachLoadBalancers -> Request DetachLoadBalancers
request Service -> Service
overrides =
    forall a. ToRequest a => Service -> a -> Request a
Request.postQuery (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy DetachLoadBalancers
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse DetachLoadBalancers)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
Text
-> (Int
    -> ResponseHeaders -> [Node] -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveXMLWrapper
      Text
"DetachLoadBalancersResult"
      ( \Int
s ResponseHeaders
h [Node]
x ->
          Int -> DetachLoadBalancersResponse
DetachLoadBalancersResponse'
            forall (f :: * -> *) a b. Functor 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 DetachLoadBalancers where
  hashWithSalt :: Int -> DetachLoadBalancers -> Int
hashWithSalt Int
_salt DetachLoadBalancers' {[Text]
Text
loadBalancerNames :: [Text]
autoScalingGroupName :: Text
$sel:loadBalancerNames:DetachLoadBalancers' :: DetachLoadBalancers -> [Text]
$sel:autoScalingGroupName:DetachLoadBalancers' :: DetachLoadBalancers -> Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
autoScalingGroupName
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` [Text]
loadBalancerNames

instance Prelude.NFData DetachLoadBalancers where
  rnf :: DetachLoadBalancers -> ()
rnf DetachLoadBalancers' {[Text]
Text
loadBalancerNames :: [Text]
autoScalingGroupName :: Text
$sel:loadBalancerNames:DetachLoadBalancers' :: DetachLoadBalancers -> [Text]
$sel:autoScalingGroupName:DetachLoadBalancers' :: DetachLoadBalancers -> Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Text
autoScalingGroupName
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf [Text]
loadBalancerNames

instance Data.ToHeaders DetachLoadBalancers where
  toHeaders :: DetachLoadBalancers -> ResponseHeaders
toHeaders = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

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

instance Data.ToQuery DetachLoadBalancers where
  toQuery :: DetachLoadBalancers -> QueryString
toQuery DetachLoadBalancers' {[Text]
Text
loadBalancerNames :: [Text]
autoScalingGroupName :: Text
$sel:loadBalancerNames:DetachLoadBalancers' :: DetachLoadBalancers -> [Text]
$sel:autoScalingGroupName:DetachLoadBalancers' :: DetachLoadBalancers -> Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"Action"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"DetachLoadBalancers" :: Prelude.ByteString),
        ByteString
"Version"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"2011-01-01" :: Prelude.ByteString),
        ByteString
"AutoScalingGroupName" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Text
autoScalingGroupName,
        ByteString
"LoadBalancerNames"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: forall a.
(IsList a, ToQuery (Item a)) =>
ByteString -> a -> QueryString
Data.toQueryList ByteString
"member" [Text]
loadBalancerNames
      ]

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

-- |
-- Create a value of 'DetachLoadBalancersResponse' 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:
--
-- 'httpStatus', 'detachLoadBalancersResponse_httpStatus' - The response's http status code.
newDetachLoadBalancersResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DetachLoadBalancersResponse
newDetachLoadBalancersResponse :: Int -> DetachLoadBalancersResponse
newDetachLoadBalancersResponse Int
pHttpStatus_ =
  DetachLoadBalancersResponse'
    { $sel:httpStatus:DetachLoadBalancersResponse' :: Int
httpStatus =
        Int
pHttpStatus_
    }

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

instance Prelude.NFData DetachLoadBalancersResponse where
  rnf :: DetachLoadBalancersResponse -> ()
rnf DetachLoadBalancersResponse' {Int
httpStatus :: Int
$sel:httpStatus:DetachLoadBalancersResponse' :: DetachLoadBalancersResponse -> Int
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus