/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
* SPDX-License-Identifier: Apache-2.0.
*/
#pragma once
#include Information about a load balancer attribute.See Also:
AWS
* API Reference
The name of the attribute.
The following attributes are supported by * both Application Load Balancers and Network Load Balancers:
* access_logs.s3.enabled - Indicates whether access logs are enabled.
* The value is true or false. The default is
* false.
access_logs.s3.bucket - The
* name of the S3 bucket for the access logs. This attribute is required if access
* logs are enabled. The bucket must exist in the same region as the load balancer
* and have a bucket policy that grants Elastic Load Balancing permissions to write
* to the bucket.
access_logs.s3.prefix - The
* prefix for the location in the S3 bucket for the access logs.
* deletion_protection.enabled - Indicates whether deletion protection
* is enabled. The value is true or false. The default is
* false.
The following attributes are supported by * only Application Load Balancers:
* idle_timeout.timeout_seconds - The idle timeout value, in seconds.
* The valid range is 1-4000 seconds. The default is 60 seconds.
* routing.http.desync_mitigation_mode - Determines how the load
* balancer handles requests that might pose a security risk to your application.
* The possible values are monitor, defensive, and
* strictest. The default is defensive.
routing.http.drop_invalid_header_fields.enabled - Indicates
* whether HTTP headers with invalid header fields are removed by the load balancer
* (true) or routed to targets (false). The default is
* false.
routing.http2.enabled -
* Indicates whether HTTP/2 is enabled. The value is true or
* false. The default is true. Elastic Load Balancing
* requires that message header names contain only alphanumeric characters and
* hyphens.
The following attributes are supported by only * Network Load Balancers:
* load_balancing.cross_zone.enabled - Indicates whether cross-zone
* load balancing is enabled. The value is true or false.
* The default is false.
The name of the attribute.
The following attributes are supported by * both Application Load Balancers and Network Load Balancers:
* access_logs.s3.enabled - Indicates whether access logs are enabled.
* The value is true or false. The default is
* false.
access_logs.s3.bucket - The
* name of the S3 bucket for the access logs. This attribute is required if access
* logs are enabled. The bucket must exist in the same region as the load balancer
* and have a bucket policy that grants Elastic Load Balancing permissions to write
* to the bucket.
access_logs.s3.prefix - The
* prefix for the location in the S3 bucket for the access logs.
* deletion_protection.enabled - Indicates whether deletion protection
* is enabled. The value is true or false. The default is
* false.
The following attributes are supported by * only Application Load Balancers:
* idle_timeout.timeout_seconds - The idle timeout value, in seconds.
* The valid range is 1-4000 seconds. The default is 60 seconds.
* routing.http.desync_mitigation_mode - Determines how the load
* balancer handles requests that might pose a security risk to your application.
* The possible values are monitor, defensive, and
* strictest. The default is defensive.
routing.http.drop_invalid_header_fields.enabled - Indicates
* whether HTTP headers with invalid header fields are removed by the load balancer
* (true) or routed to targets (false). The default is
* false.
routing.http2.enabled -
* Indicates whether HTTP/2 is enabled. The value is true or
* false. The default is true. Elastic Load Balancing
* requires that message header names contain only alphanumeric characters and
* hyphens.
The following attributes are supported by only * Network Load Balancers:
* load_balancing.cross_zone.enabled - Indicates whether cross-zone
* load balancing is enabled. The value is true or false.
* The default is false.
The name of the attribute.
The following attributes are supported by * both Application Load Balancers and Network Load Balancers:
* access_logs.s3.enabled - Indicates whether access logs are enabled.
* The value is true or false. The default is
* false.
access_logs.s3.bucket - The
* name of the S3 bucket for the access logs. This attribute is required if access
* logs are enabled. The bucket must exist in the same region as the load balancer
* and have a bucket policy that grants Elastic Load Balancing permissions to write
* to the bucket.
access_logs.s3.prefix - The
* prefix for the location in the S3 bucket for the access logs.
* deletion_protection.enabled - Indicates whether deletion protection
* is enabled. The value is true or false. The default is
* false.
The following attributes are supported by * only Application Load Balancers:
* idle_timeout.timeout_seconds - The idle timeout value, in seconds.
* The valid range is 1-4000 seconds. The default is 60 seconds.
* routing.http.desync_mitigation_mode - Determines how the load
* balancer handles requests that might pose a security risk to your application.
* The possible values are monitor, defensive, and
* strictest. The default is defensive.
routing.http.drop_invalid_header_fields.enabled - Indicates
* whether HTTP headers with invalid header fields are removed by the load balancer
* (true) or routed to targets (false). The default is
* false.
routing.http2.enabled -
* Indicates whether HTTP/2 is enabled. The value is true or
* false. The default is true. Elastic Load Balancing
* requires that message header names contain only alphanumeric characters and
* hyphens.
The following attributes are supported by only * Network Load Balancers:
* load_balancing.cross_zone.enabled - Indicates whether cross-zone
* load balancing is enabled. The value is true or false.
* The default is false.
The name of the attribute.
The following attributes are supported by * both Application Load Balancers and Network Load Balancers:
* access_logs.s3.enabled - Indicates whether access logs are enabled.
* The value is true or false. The default is
* false.
access_logs.s3.bucket - The
* name of the S3 bucket for the access logs. This attribute is required if access
* logs are enabled. The bucket must exist in the same region as the load balancer
* and have a bucket policy that grants Elastic Load Balancing permissions to write
* to the bucket.
access_logs.s3.prefix - The
* prefix for the location in the S3 bucket for the access logs.
* deletion_protection.enabled - Indicates whether deletion protection
* is enabled. The value is true or false. The default is
* false.
The following attributes are supported by * only Application Load Balancers:
* idle_timeout.timeout_seconds - The idle timeout value, in seconds.
* The valid range is 1-4000 seconds. The default is 60 seconds.
* routing.http.desync_mitigation_mode - Determines how the load
* balancer handles requests that might pose a security risk to your application.
* The possible values are monitor, defensive, and
* strictest. The default is defensive.
routing.http.drop_invalid_header_fields.enabled - Indicates
* whether HTTP headers with invalid header fields are removed by the load balancer
* (true) or routed to targets (false). The default is
* false.
routing.http2.enabled -
* Indicates whether HTTP/2 is enabled. The value is true or
* false. The default is true. Elastic Load Balancing
* requires that message header names contain only alphanumeric characters and
* hyphens.
The following attributes are supported by only * Network Load Balancers:
* load_balancing.cross_zone.enabled - Indicates whether cross-zone
* load balancing is enabled. The value is true or false.
* The default is false.
The name of the attribute.
The following attributes are supported by * both Application Load Balancers and Network Load Balancers:
* access_logs.s3.enabled - Indicates whether access logs are enabled.
* The value is true or false. The default is
* false.
access_logs.s3.bucket - The
* name of the S3 bucket for the access logs. This attribute is required if access
* logs are enabled. The bucket must exist in the same region as the load balancer
* and have a bucket policy that grants Elastic Load Balancing permissions to write
* to the bucket.
access_logs.s3.prefix - The
* prefix for the location in the S3 bucket for the access logs.
* deletion_protection.enabled - Indicates whether deletion protection
* is enabled. The value is true or false. The default is
* false.
The following attributes are supported by * only Application Load Balancers:
* idle_timeout.timeout_seconds - The idle timeout value, in seconds.
* The valid range is 1-4000 seconds. The default is 60 seconds.
* routing.http.desync_mitigation_mode - Determines how the load
* balancer handles requests that might pose a security risk to your application.
* The possible values are monitor, defensive, and
* strictest. The default is defensive.
routing.http.drop_invalid_header_fields.enabled - Indicates
* whether HTTP headers with invalid header fields are removed by the load balancer
* (true) or routed to targets (false). The default is
* false.
routing.http2.enabled -
* Indicates whether HTTP/2 is enabled. The value is true or
* false. The default is true. Elastic Load Balancing
* requires that message header names contain only alphanumeric characters and
* hyphens.
The following attributes are supported by only * Network Load Balancers:
* load_balancing.cross_zone.enabled - Indicates whether cross-zone
* load balancing is enabled. The value is true or false.
* The default is false.
The name of the attribute.
The following attributes are supported by * both Application Load Balancers and Network Load Balancers:
* access_logs.s3.enabled - Indicates whether access logs are enabled.
* The value is true or false. The default is
* false.
access_logs.s3.bucket - The
* name of the S3 bucket for the access logs. This attribute is required if access
* logs are enabled. The bucket must exist in the same region as the load balancer
* and have a bucket policy that grants Elastic Load Balancing permissions to write
* to the bucket.
access_logs.s3.prefix - The
* prefix for the location in the S3 bucket for the access logs.
* deletion_protection.enabled - Indicates whether deletion protection
* is enabled. The value is true or false. The default is
* false.
The following attributes are supported by * only Application Load Balancers:
* idle_timeout.timeout_seconds - The idle timeout value, in seconds.
* The valid range is 1-4000 seconds. The default is 60 seconds.
* routing.http.desync_mitigation_mode - Determines how the load
* balancer handles requests that might pose a security risk to your application.
* The possible values are monitor, defensive, and
* strictest. The default is defensive.
routing.http.drop_invalid_header_fields.enabled - Indicates
* whether HTTP headers with invalid header fields are removed by the load balancer
* (true) or routed to targets (false). The default is
* false.
routing.http2.enabled -
* Indicates whether HTTP/2 is enabled. The value is true or
* false. The default is true. Elastic Load Balancing
* requires that message header names contain only alphanumeric characters and
* hyphens.
The following attributes are supported by only * Network Load Balancers:
* load_balancing.cross_zone.enabled - Indicates whether cross-zone
* load balancing is enabled. The value is true or false.
* The default is false.
The name of the attribute.
The following attributes are supported by * both Application Load Balancers and Network Load Balancers:
* access_logs.s3.enabled - Indicates whether access logs are enabled.
* The value is true or false. The default is
* false.
access_logs.s3.bucket - The
* name of the S3 bucket for the access logs. This attribute is required if access
* logs are enabled. The bucket must exist in the same region as the load balancer
* and have a bucket policy that grants Elastic Load Balancing permissions to write
* to the bucket.
access_logs.s3.prefix - The
* prefix for the location in the S3 bucket for the access logs.
* deletion_protection.enabled - Indicates whether deletion protection
* is enabled. The value is true or false. The default is
* false.
The following attributes are supported by * only Application Load Balancers:
* idle_timeout.timeout_seconds - The idle timeout value, in seconds.
* The valid range is 1-4000 seconds. The default is 60 seconds.
* routing.http.desync_mitigation_mode - Determines how the load
* balancer handles requests that might pose a security risk to your application.
* The possible values are monitor, defensive, and
* strictest. The default is defensive.
routing.http.drop_invalid_header_fields.enabled - Indicates
* whether HTTP headers with invalid header fields are removed by the load balancer
* (true) or routed to targets (false). The default is
* false.
routing.http2.enabled -
* Indicates whether HTTP/2 is enabled. The value is true or
* false. The default is true. Elastic Load Balancing
* requires that message header names contain only alphanumeric characters and
* hyphens.
The following attributes are supported by only * Network Load Balancers:
* load_balancing.cross_zone.enabled - Indicates whether cross-zone
* load balancing is enabled. The value is true or false.
* The default is false.
The name of the attribute.
The following attributes are supported by * both Application Load Balancers and Network Load Balancers:
* access_logs.s3.enabled - Indicates whether access logs are enabled.
* The value is true or false. The default is
* false.
access_logs.s3.bucket - The
* name of the S3 bucket for the access logs. This attribute is required if access
* logs are enabled. The bucket must exist in the same region as the load balancer
* and have a bucket policy that grants Elastic Load Balancing permissions to write
* to the bucket.
access_logs.s3.prefix - The
* prefix for the location in the S3 bucket for the access logs.
* deletion_protection.enabled - Indicates whether deletion protection
* is enabled. The value is true or false. The default is
* false.
The following attributes are supported by * only Application Load Balancers:
* idle_timeout.timeout_seconds - The idle timeout value, in seconds.
* The valid range is 1-4000 seconds. The default is 60 seconds.
* routing.http.desync_mitigation_mode - Determines how the load
* balancer handles requests that might pose a security risk to your application.
* The possible values are monitor, defensive, and
* strictest. The default is defensive.
routing.http.drop_invalid_header_fields.enabled - Indicates
* whether HTTP headers with invalid header fields are removed by the load balancer
* (true) or routed to targets (false). The default is
* false.
routing.http2.enabled -
* Indicates whether HTTP/2 is enabled. The value is true or
* false. The default is true. Elastic Load Balancing
* requires that message header names contain only alphanumeric characters and
* hyphens.
The following attributes are supported by only * Network Load Balancers:
* load_balancing.cross_zone.enabled - Indicates whether cross-zone
* load balancing is enabled. The value is true or false.
* The default is false.
The value of the attribute.
*/ inline const Aws::String& GetValue() const{ return m_value; } /** *The value of the attribute.
*/ inline bool ValueHasBeenSet() const { return m_valueHasBeenSet; } /** *The value of the attribute.
*/ inline void SetValue(const Aws::String& value) { m_valueHasBeenSet = true; m_value = value; } /** *The value of the attribute.
*/ inline void SetValue(Aws::String&& value) { m_valueHasBeenSet = true; m_value = std::move(value); } /** *The value of the attribute.
*/ inline void SetValue(const char* value) { m_valueHasBeenSet = true; m_value.assign(value); } /** *The value of the attribute.
*/ inline LoadBalancerAttribute& WithValue(const Aws::String& value) { SetValue(value); return *this;} /** *The value of the attribute.
*/ inline LoadBalancerAttribute& WithValue(Aws::String&& value) { SetValue(std::move(value)); return *this;} /** *The value of the attribute.
*/ inline LoadBalancerAttribute& WithValue(const char* value) { SetValue(value); return *this;} private: Aws::String m_key; bool m_keyHasBeenSet; Aws::String m_value; bool m_valueHasBeenSet; }; } // namespace Model } // namespace ElasticLoadBalancingv2 } // namespace Aws