/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include #include namespace Aws { namespace Utils { namespace Xml { class XmlNode; } // namespace Xml } // namespace Utils namespace ElasticLoadBalancingv2 { namespace Model { /** *

Information about a load balancer attribute.

See Also:

AWS * API Reference

*/ class AWS_ELASTICLOADBALANCINGV2_API LoadBalancerAttribute { public: LoadBalancerAttribute(); LoadBalancerAttribute(const Aws::Utils::Xml::XmlNode& xmlNode); LoadBalancerAttribute& operator=(const Aws::Utils::Xml::XmlNode& xmlNode); void OutputToStream(Aws::OStream& ostream, const char* location, unsigned index, const char* locationValue) const; void OutputToStream(Aws::OStream& oStream, const char* location) const; /** *

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.

*/ inline const Aws::String& GetKey() const{ return m_key; } /** *

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.

*/ inline bool KeyHasBeenSet() const { return m_keyHasBeenSet; } /** *

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.

*/ inline void SetKey(const Aws::String& value) { m_keyHasBeenSet = true; m_key = value; } /** *

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.

*/ inline void SetKey(Aws::String&& value) { m_keyHasBeenSet = true; m_key = std::move(value); } /** *

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.

*/ inline void SetKey(const char* value) { m_keyHasBeenSet = true; m_key.assign(value); } /** *

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.

*/ inline LoadBalancerAttribute& WithKey(const Aws::String& value) { SetKey(value); return *this;} /** *

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.

*/ inline LoadBalancerAttribute& WithKey(Aws::String&& value) { SetKey(std::move(value)); return *this;} /** *

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.

*/ inline LoadBalancerAttribute& WithKey(const char* value) { SetKey(value); return *this;} /** *

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