{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE NamedFieldPuns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE NoImplicitPrelude #-} {-# 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.Types.LoadBalancer -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) module Amazonka.ECS.Types.LoadBalancer where 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 -- | The load balancer configuration to use with a service or task set. -- -- For specific notes and restrictions regarding the use of load balancers -- with services and task sets, see the CreateService and CreateTaskSet -- actions. -- -- When you add, update, or remove a load balancer configuration, Amazon -- ECS starts a new deployment with the updated Elastic Load Balancing -- configuration. This causes tasks to register to and deregister from load -- balancers. -- -- We recommend that you verify this on a test environment before you -- update the Elastic Load Balancing configuration. -- -- A service-linked role is required for services that use multiple target -- groups. For more information, see -- -- in the /Amazon Elastic Container Service Developer Guide/. -- -- /See:/ 'newLoadBalancer' smart constructor. data LoadBalancer = LoadBalancer' { -- | The name of the container (as it appears in a container definition) to -- associate with the load balancer. containerName :: Prelude.Maybe Prelude.Text, -- | The port on the container to associate with the load balancer. This port -- must correspond to a @containerPort@ in the task definition the tasks in -- the service are using. For tasks that use the EC2 launch type, the -- container instance they\'re launched on must allow ingress traffic on -- the @hostPort@ of the port mapping. containerPort :: Prelude.Maybe Prelude.Int, -- | The name of the load balancer to associate with the Amazon ECS service -- or task set. -- -- A load balancer name is only specified when using a Classic Load -- Balancer. If you are using an Application Load Balancer or a Network -- Load Balancer the load balancer name parameter should be omitted. loadBalancerName :: Prelude.Maybe Prelude.Text, -- | The full Amazon Resource Name (ARN) of the Elastic Load Balancing target -- group or groups associated with a service or task set. -- -- A target group ARN is only specified when using an Application Load -- Balancer or Network Load Balancer. If you\'re using a Classic Load -- Balancer, omit the target group ARN. -- -- For services using the @ECS@ deployment controller, you can specify one -- or multiple target groups. For more information, see -- -- in the /Amazon Elastic Container Service Developer Guide/. -- -- For services using the @CODE_DEPLOY@ deployment controller, you\'re -- required to define two target groups for the load balancer. For more -- information, see -- -- in the /Amazon Elastic Container Service Developer Guide/. -- -- If your service\'s task definition uses the @awsvpc@ network mode, you -- must choose @ip@ as the target type, not @instance@. Do this when -- creating your target groups because tasks that use the @awsvpc@ network -- mode are associated with an elastic network interface, not an Amazon EC2 -- instance. This network mode is required for the Fargate launch type. targetGroupArn :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'LoadBalancer' 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: -- -- 'containerName', 'loadBalancer_containerName' - The name of the container (as it appears in a container definition) to -- associate with the load balancer. -- -- 'containerPort', 'loadBalancer_containerPort' - The port on the container to associate with the load balancer. This port -- must correspond to a @containerPort@ in the task definition the tasks in -- the service are using. For tasks that use the EC2 launch type, the -- container instance they\'re launched on must allow ingress traffic on -- the @hostPort@ of the port mapping. -- -- 'loadBalancerName', 'loadBalancer_loadBalancerName' - The name of the load balancer to associate with the Amazon ECS service -- or task set. -- -- A load balancer name is only specified when using a Classic Load -- Balancer. If you are using an Application Load Balancer or a Network -- Load Balancer the load balancer name parameter should be omitted. -- -- 'targetGroupArn', 'loadBalancer_targetGroupArn' - The full Amazon Resource Name (ARN) of the Elastic Load Balancing target -- group or groups associated with a service or task set. -- -- A target group ARN is only specified when using an Application Load -- Balancer or Network Load Balancer. If you\'re using a Classic Load -- Balancer, omit the target group ARN. -- -- For services using the @ECS@ deployment controller, you can specify one -- or multiple target groups. For more information, see -- -- in the /Amazon Elastic Container Service Developer Guide/. -- -- For services using the @CODE_DEPLOY@ deployment controller, you\'re -- required to define two target groups for the load balancer. For more -- information, see -- -- in the /Amazon Elastic Container Service Developer Guide/. -- -- If your service\'s task definition uses the @awsvpc@ network mode, you -- must choose @ip@ as the target type, not @instance@. Do this when -- creating your target groups because tasks that use the @awsvpc@ network -- mode are associated with an elastic network interface, not an Amazon EC2 -- instance. This network mode is required for the Fargate launch type. newLoadBalancer :: LoadBalancer newLoadBalancer = LoadBalancer' { containerName = Prelude.Nothing, containerPort = Prelude.Nothing, loadBalancerName = Prelude.Nothing, targetGroupArn = Prelude.Nothing } -- | The name of the container (as it appears in a container definition) to -- associate with the load balancer. loadBalancer_containerName :: Lens.Lens' LoadBalancer (Prelude.Maybe Prelude.Text) loadBalancer_containerName = Lens.lens (\LoadBalancer' {containerName} -> containerName) (\s@LoadBalancer' {} a -> s {containerName = a} :: LoadBalancer) -- | The port on the container to associate with the load balancer. This port -- must correspond to a @containerPort@ in the task definition the tasks in -- the service are using. For tasks that use the EC2 launch type, the -- container instance they\'re launched on must allow ingress traffic on -- the @hostPort@ of the port mapping. loadBalancer_containerPort :: Lens.Lens' LoadBalancer (Prelude.Maybe Prelude.Int) loadBalancer_containerPort = Lens.lens (\LoadBalancer' {containerPort} -> containerPort) (\s@LoadBalancer' {} a -> s {containerPort = a} :: LoadBalancer) -- | The name of the load balancer to associate with the Amazon ECS service -- or task set. -- -- A load balancer name is only specified when using a Classic Load -- Balancer. If you are using an Application Load Balancer or a Network -- Load Balancer the load balancer name parameter should be omitted. loadBalancer_loadBalancerName :: Lens.Lens' LoadBalancer (Prelude.Maybe Prelude.Text) loadBalancer_loadBalancerName = Lens.lens (\LoadBalancer' {loadBalancerName} -> loadBalancerName) (\s@LoadBalancer' {} a -> s {loadBalancerName = a} :: LoadBalancer) -- | The full Amazon Resource Name (ARN) of the Elastic Load Balancing target -- group or groups associated with a service or task set. -- -- A target group ARN is only specified when using an Application Load -- Balancer or Network Load Balancer. If you\'re using a Classic Load -- Balancer, omit the target group ARN. -- -- For services using the @ECS@ deployment controller, you can specify one -- or multiple target groups. For more information, see -- -- in the /Amazon Elastic Container Service Developer Guide/. -- -- For services using the @CODE_DEPLOY@ deployment controller, you\'re -- required to define two target groups for the load balancer. For more -- information, see -- -- in the /Amazon Elastic Container Service Developer Guide/. -- -- If your service\'s task definition uses the @awsvpc@ network mode, you -- must choose @ip@ as the target type, not @instance@. Do this when -- creating your target groups because tasks that use the @awsvpc@ network -- mode are associated with an elastic network interface, not an Amazon EC2 -- instance. This network mode is required for the Fargate launch type. loadBalancer_targetGroupArn :: Lens.Lens' LoadBalancer (Prelude.Maybe Prelude.Text) loadBalancer_targetGroupArn = Lens.lens (\LoadBalancer' {targetGroupArn} -> targetGroupArn) (\s@LoadBalancer' {} a -> s {targetGroupArn = a} :: LoadBalancer) instance Data.FromJSON LoadBalancer where parseJSON = Data.withObject "LoadBalancer" ( \x -> LoadBalancer' Prelude.<$> (x Data..:? "containerName") Prelude.<*> (x Data..:? "containerPort") Prelude.<*> (x Data..:? "loadBalancerName") Prelude.<*> (x Data..:? "targetGroupArn") ) instance Prelude.Hashable LoadBalancer where hashWithSalt _salt LoadBalancer' {..} = _salt `Prelude.hashWithSalt` containerName `Prelude.hashWithSalt` containerPort `Prelude.hashWithSalt` loadBalancerName `Prelude.hashWithSalt` targetGroupArn instance Prelude.NFData LoadBalancer where rnf LoadBalancer' {..} = Prelude.rnf containerName `Prelude.seq` Prelude.rnf containerPort `Prelude.seq` Prelude.rnf loadBalancerName `Prelude.seq` Prelude.rnf targetGroupArn instance Data.ToJSON LoadBalancer where toJSON LoadBalancer' {..} = Data.object ( Prelude.catMaybes [ ("containerName" Data..=) Prelude.<$> containerName, ("containerPort" Data..=) Prelude.<$> containerPort, ("loadBalancerName" Data..=) Prelude.<$> loadBalancerName, ("targetGroupArn" Data..=) Prelude.<$> targetGroupArn ] )