{-# 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.ELB.SetLoadBalancerPoliciesForBackendServer -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Replaces the set of policies associated with the specified port on which -- the EC2 instance is listening with a new set of policies. At this time, -- only the back-end server authentication policy type can be applied to -- the instance ports; this policy type is composed of multiple public key -- policies. -- -- Each time you use @SetLoadBalancerPoliciesForBackendServer@ to enable -- the policies, use the @PolicyNames@ parameter to list the policies that -- you want to enable. -- -- You can use DescribeLoadBalancers or DescribeLoadBalancerPolicies to -- verify that the policy is associated with the EC2 instance. -- -- For more information about enabling back-end instance authentication, -- see -- -- in the /Classic Load Balancers Guide/. For more information about Proxy -- Protocol, see -- -- in the /Classic Load Balancers Guide/. module Amazonka.ELB.SetLoadBalancerPoliciesForBackendServer ( -- * Creating a Request SetLoadBalancerPoliciesForBackendServer (..), newSetLoadBalancerPoliciesForBackendServer, -- * Request Lenses setLoadBalancerPoliciesForBackendServer_loadBalancerName, setLoadBalancerPoliciesForBackendServer_instancePort, setLoadBalancerPoliciesForBackendServer_policyNames, -- * Destructuring the Response SetLoadBalancerPoliciesForBackendServerResponse (..), newSetLoadBalancerPoliciesForBackendServerResponse, -- * Response Lenses setLoadBalancerPoliciesForBackendServerResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.ELB.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | Contains the parameters for SetLoadBalancerPoliciesForBackendServer. -- -- /See:/ 'newSetLoadBalancerPoliciesForBackendServer' smart constructor. data SetLoadBalancerPoliciesForBackendServer = SetLoadBalancerPoliciesForBackendServer' { -- | The name of the load balancer. loadBalancerName :: Prelude.Text, -- | The port number associated with the EC2 instance. instancePort :: Prelude.Int, -- | The names of the policies. If the list is empty, then all current -- polices are removed from the EC2 instance. policyNames :: [Prelude.Text] } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'SetLoadBalancerPoliciesForBackendServer' 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: -- -- 'loadBalancerName', 'setLoadBalancerPoliciesForBackendServer_loadBalancerName' - The name of the load balancer. -- -- 'instancePort', 'setLoadBalancerPoliciesForBackendServer_instancePort' - The port number associated with the EC2 instance. -- -- 'policyNames', 'setLoadBalancerPoliciesForBackendServer_policyNames' - The names of the policies. If the list is empty, then all current -- polices are removed from the EC2 instance. newSetLoadBalancerPoliciesForBackendServer :: -- | 'loadBalancerName' Prelude.Text -> -- | 'instancePort' Prelude.Int -> SetLoadBalancerPoliciesForBackendServer newSetLoadBalancerPoliciesForBackendServer pLoadBalancerName_ pInstancePort_ = SetLoadBalancerPoliciesForBackendServer' { loadBalancerName = pLoadBalancerName_, instancePort = pInstancePort_, policyNames = Prelude.mempty } -- | The name of the load balancer. setLoadBalancerPoliciesForBackendServer_loadBalancerName :: Lens.Lens' SetLoadBalancerPoliciesForBackendServer Prelude.Text setLoadBalancerPoliciesForBackendServer_loadBalancerName = Lens.lens (\SetLoadBalancerPoliciesForBackendServer' {loadBalancerName} -> loadBalancerName) (\s@SetLoadBalancerPoliciesForBackendServer' {} a -> s {loadBalancerName = a} :: SetLoadBalancerPoliciesForBackendServer) -- | The port number associated with the EC2 instance. setLoadBalancerPoliciesForBackendServer_instancePort :: Lens.Lens' SetLoadBalancerPoliciesForBackendServer Prelude.Int setLoadBalancerPoliciesForBackendServer_instancePort = Lens.lens (\SetLoadBalancerPoliciesForBackendServer' {instancePort} -> instancePort) (\s@SetLoadBalancerPoliciesForBackendServer' {} a -> s {instancePort = a} :: SetLoadBalancerPoliciesForBackendServer) -- | The names of the policies. If the list is empty, then all current -- polices are removed from the EC2 instance. setLoadBalancerPoliciesForBackendServer_policyNames :: Lens.Lens' SetLoadBalancerPoliciesForBackendServer [Prelude.Text] setLoadBalancerPoliciesForBackendServer_policyNames = Lens.lens (\SetLoadBalancerPoliciesForBackendServer' {policyNames} -> policyNames) (\s@SetLoadBalancerPoliciesForBackendServer' {} a -> s {policyNames = a} :: SetLoadBalancerPoliciesForBackendServer) Prelude.. Lens.coerced instance Core.AWSRequest SetLoadBalancerPoliciesForBackendServer where type AWSResponse SetLoadBalancerPoliciesForBackendServer = SetLoadBalancerPoliciesForBackendServerResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXMLWrapper "SetLoadBalancerPoliciesForBackendServerResult" ( \s h x -> SetLoadBalancerPoliciesForBackendServerResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable SetLoadBalancerPoliciesForBackendServer where hashWithSalt _salt SetLoadBalancerPoliciesForBackendServer' {..} = _salt `Prelude.hashWithSalt` loadBalancerName `Prelude.hashWithSalt` instancePort `Prelude.hashWithSalt` policyNames instance Prelude.NFData SetLoadBalancerPoliciesForBackendServer where rnf SetLoadBalancerPoliciesForBackendServer' {..} = Prelude.rnf loadBalancerName `Prelude.seq` Prelude.rnf instancePort `Prelude.seq` Prelude.rnf policyNames instance Data.ToHeaders SetLoadBalancerPoliciesForBackendServer where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath SetLoadBalancerPoliciesForBackendServer where toPath = Prelude.const "/" instance Data.ToQuery SetLoadBalancerPoliciesForBackendServer where toQuery SetLoadBalancerPoliciesForBackendServer' {..} = Prelude.mconcat [ "Action" Data.=: ( "SetLoadBalancerPoliciesForBackendServer" :: Prelude.ByteString ), "Version" Data.=: ("2012-06-01" :: Prelude.ByteString), "LoadBalancerName" Data.=: loadBalancerName, "InstancePort" Data.=: instancePort, "PolicyNames" Data.=: Data.toQueryList "member" policyNames ] -- | Contains the output of SetLoadBalancerPoliciesForBackendServer. -- -- /See:/ 'newSetLoadBalancerPoliciesForBackendServerResponse' smart constructor. data SetLoadBalancerPoliciesForBackendServerResponse = SetLoadBalancerPoliciesForBackendServerResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'SetLoadBalancerPoliciesForBackendServerResponse' 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', 'setLoadBalancerPoliciesForBackendServerResponse_httpStatus' - The response's http status code. newSetLoadBalancerPoliciesForBackendServerResponse :: -- | 'httpStatus' Prelude.Int -> SetLoadBalancerPoliciesForBackendServerResponse newSetLoadBalancerPoliciesForBackendServerResponse pHttpStatus_ = SetLoadBalancerPoliciesForBackendServerResponse' { httpStatus = pHttpStatus_ } -- | The response's http status code. setLoadBalancerPoliciesForBackendServerResponse_httpStatus :: Lens.Lens' SetLoadBalancerPoliciesForBackendServerResponse Prelude.Int setLoadBalancerPoliciesForBackendServerResponse_httpStatus = Lens.lens (\SetLoadBalancerPoliciesForBackendServerResponse' {httpStatus} -> httpStatus) (\s@SetLoadBalancerPoliciesForBackendServerResponse' {} a -> s {httpStatus = a} :: SetLoadBalancerPoliciesForBackendServerResponse) instance Prelude.NFData SetLoadBalancerPoliciesForBackendServerResponse where rnf SetLoadBalancerPoliciesForBackendServerResponse' {..} = Prelude.rnf httpStatus