{-# 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. autoScalingGroupName :: Prelude.Text, -- | The names of the load balancers. You can specify up to 10 load -- balancers. loadBalancerNames :: [Prelude.Text] } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DetachLoadBalancers' 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: -- -- '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 pAutoScalingGroupName_ = DetachLoadBalancers' { autoScalingGroupName = pAutoScalingGroupName_, loadBalancerNames = Prelude.mempty } -- | The name of the Auto Scaling group. detachLoadBalancers_autoScalingGroupName :: Lens.Lens' DetachLoadBalancers Prelude.Text detachLoadBalancers_autoScalingGroupName = Lens.lens (\DetachLoadBalancers' {autoScalingGroupName} -> autoScalingGroupName) (\s@DetachLoadBalancers' {} a -> s {autoScalingGroupName = 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.lens (\DetachLoadBalancers' {loadBalancerNames} -> loadBalancerNames) (\s@DetachLoadBalancers' {} a -> s {loadBalancerNames = a} :: DetachLoadBalancers) Prelude.. Lens.coerced instance Core.AWSRequest DetachLoadBalancers where type AWSResponse DetachLoadBalancers = DetachLoadBalancersResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXMLWrapper "DetachLoadBalancersResult" ( \s h x -> DetachLoadBalancersResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DetachLoadBalancers where hashWithSalt _salt DetachLoadBalancers' {..} = _salt `Prelude.hashWithSalt` autoScalingGroupName `Prelude.hashWithSalt` loadBalancerNames instance Prelude.NFData DetachLoadBalancers where rnf DetachLoadBalancers' {..} = Prelude.rnf autoScalingGroupName `Prelude.seq` Prelude.rnf loadBalancerNames instance Data.ToHeaders DetachLoadBalancers where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath DetachLoadBalancers where toPath = Prelude.const "/" instance Data.ToQuery DetachLoadBalancers where toQuery DetachLoadBalancers' {..} = Prelude.mconcat [ "Action" Data.=: ("DetachLoadBalancers" :: Prelude.ByteString), "Version" Data.=: ("2011-01-01" :: Prelude.ByteString), "AutoScalingGroupName" Data.=: autoScalingGroupName, "LoadBalancerNames" Data.=: Data.toQueryList "member" loadBalancerNames ] -- | /See:/ 'newDetachLoadBalancersResponse' smart constructor. data DetachLoadBalancersResponse = DetachLoadBalancersResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DetachLoadBalancersResponse' 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', 'detachLoadBalancersResponse_httpStatus' - The response's http status code. newDetachLoadBalancersResponse :: -- | 'httpStatus' Prelude.Int -> DetachLoadBalancersResponse newDetachLoadBalancersResponse pHttpStatus_ = DetachLoadBalancersResponse' { httpStatus = pHttpStatus_ } -- | The response's http status code. detachLoadBalancersResponse_httpStatus :: Lens.Lens' DetachLoadBalancersResponse Prelude.Int detachLoadBalancersResponse_httpStatus = Lens.lens (\DetachLoadBalancersResponse' {httpStatus} -> httpStatus) (\s@DetachLoadBalancersResponse' {} a -> s {httpStatus = a} :: DetachLoadBalancersResponse) instance Prelude.NFData DetachLoadBalancersResponse where rnf DetachLoadBalancersResponse' {..} = Prelude.rnf httpStatus