/** * 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 Json { class JsonValue; class JsonView; } // namespace Json } // namespace Utils namespace WAF { namespace Model { /** *

This is AWS WAF Classic documentation. For more information, * see AWS * WAF Classic in the developer guide.

For the latest version of AWS * WAF, use the AWS WAFV2 API and see the AWS * WAF Developer Guide. With the latest version, AWS WAF has a single set of * endpoints for regional and global use.

Specifies the IP address * type (IPV4 or IPV6) and the IP address range (in CIDR * format) that web requests originate from.

See Also:

AWS * API Reference

*/ class IPSetDescriptor { public: AWS_WAF_API IPSetDescriptor(); AWS_WAF_API IPSetDescriptor(Aws::Utils::Json::JsonView jsonValue); AWS_WAF_API IPSetDescriptor& operator=(Aws::Utils::Json::JsonView jsonValue); AWS_WAF_API Aws::Utils::Json::JsonValue Jsonize() const; /** *

Specify IPV4 or IPV6.

*/ inline const IPSetDescriptorType& GetType() const{ return m_type; } /** *

Specify IPV4 or IPV6.

*/ inline bool TypeHasBeenSet() const { return m_typeHasBeenSet; } /** *

Specify IPV4 or IPV6.

*/ inline void SetType(const IPSetDescriptorType& value) { m_typeHasBeenSet = true; m_type = value; } /** *

Specify IPV4 or IPV6.

*/ inline void SetType(IPSetDescriptorType&& value) { m_typeHasBeenSet = true; m_type = std::move(value); } /** *

Specify IPV4 or IPV6.

*/ inline IPSetDescriptor& WithType(const IPSetDescriptorType& value) { SetType(value); return *this;} /** *

Specify IPV4 or IPV6.

*/ inline IPSetDescriptor& WithType(IPSetDescriptorType&& value) { SetType(std::move(value)); return *this;} /** *

Specify an IPv4 address by using CIDR notation. For example:

  • *

    To configure AWS WAF to allow, block, or count requests that originated from * the IP address 192.0.2.44, specify 192.0.2.44/32.

  • *

    To configure AWS WAF to allow, block, or count requests that originated from * IP addresses from 192.0.2.0 to 192.0.2.255, specify * 192.0.2.0/24.

For more information about CIDR * notation, see the Wikipedia entry Classless * Inter-Domain Routing.

Specify an IPv6 address by using CIDR notation. * For example:

  • To configure AWS WAF to allow, block, or count * requests that originated from the IP address * 1111:0000:0000:0000:0000:0000:0000:0111, specify * 1111:0000:0000:0000:0000:0000:0000:0111/128.

  • To * configure AWS WAF to allow, block, or count requests that originated from IP * addresses 1111:0000:0000:0000:0000:0000:0000:0000 to * 1111:0000:0000:0000:ffff:ffff:ffff:ffff, specify * 1111:0000:0000:0000:0000:0000:0000:0000/64.

*/ inline const Aws::String& GetValue() const{ return m_value; } /** *

Specify an IPv4 address by using CIDR notation. For example:

  • *

    To configure AWS WAF to allow, block, or count requests that originated from * the IP address 192.0.2.44, specify 192.0.2.44/32.

  • *

    To configure AWS WAF to allow, block, or count requests that originated from * IP addresses from 192.0.2.0 to 192.0.2.255, specify * 192.0.2.0/24.

For more information about CIDR * notation, see the Wikipedia entry Classless * Inter-Domain Routing.

Specify an IPv6 address by using CIDR notation. * For example:

  • To configure AWS WAF to allow, block, or count * requests that originated from the IP address * 1111:0000:0000:0000:0000:0000:0000:0111, specify * 1111:0000:0000:0000:0000:0000:0000:0111/128.

  • To * configure AWS WAF to allow, block, or count requests that originated from IP * addresses 1111:0000:0000:0000:0000:0000:0000:0000 to * 1111:0000:0000:0000:ffff:ffff:ffff:ffff, specify * 1111:0000:0000:0000:0000:0000:0000:0000/64.

*/ inline bool ValueHasBeenSet() const { return m_valueHasBeenSet; } /** *

Specify an IPv4 address by using CIDR notation. For example:

  • *

    To configure AWS WAF to allow, block, or count requests that originated from * the IP address 192.0.2.44, specify 192.0.2.44/32.

  • *

    To configure AWS WAF to allow, block, or count requests that originated from * IP addresses from 192.0.2.0 to 192.0.2.255, specify * 192.0.2.0/24.

For more information about CIDR * notation, see the Wikipedia entry Classless * Inter-Domain Routing.

Specify an IPv6 address by using CIDR notation. * For example:

  • To configure AWS WAF to allow, block, or count * requests that originated from the IP address * 1111:0000:0000:0000:0000:0000:0000:0111, specify * 1111:0000:0000:0000:0000:0000:0000:0111/128.

  • To * configure AWS WAF to allow, block, or count requests that originated from IP * addresses 1111:0000:0000:0000:0000:0000:0000:0000 to * 1111:0000:0000:0000:ffff:ffff:ffff:ffff, specify * 1111:0000:0000:0000:0000:0000:0000:0000/64.

*/ inline void SetValue(const Aws::String& value) { m_valueHasBeenSet = true; m_value = value; } /** *

Specify an IPv4 address by using CIDR notation. For example:

  • *

    To configure AWS WAF to allow, block, or count requests that originated from * the IP address 192.0.2.44, specify 192.0.2.44/32.

  • *

    To configure AWS WAF to allow, block, or count requests that originated from * IP addresses from 192.0.2.0 to 192.0.2.255, specify * 192.0.2.0/24.

For more information about CIDR * notation, see the Wikipedia entry Classless * Inter-Domain Routing.

Specify an IPv6 address by using CIDR notation. * For example:

  • To configure AWS WAF to allow, block, or count * requests that originated from the IP address * 1111:0000:0000:0000:0000:0000:0000:0111, specify * 1111:0000:0000:0000:0000:0000:0000:0111/128.

  • To * configure AWS WAF to allow, block, or count requests that originated from IP * addresses 1111:0000:0000:0000:0000:0000:0000:0000 to * 1111:0000:0000:0000:ffff:ffff:ffff:ffff, specify * 1111:0000:0000:0000:0000:0000:0000:0000/64.

*/ inline void SetValue(Aws::String&& value) { m_valueHasBeenSet = true; m_value = std::move(value); } /** *

Specify an IPv4 address by using CIDR notation. For example:

  • *

    To configure AWS WAF to allow, block, or count requests that originated from * the IP address 192.0.2.44, specify 192.0.2.44/32.

  • *

    To configure AWS WAF to allow, block, or count requests that originated from * IP addresses from 192.0.2.0 to 192.0.2.255, specify * 192.0.2.0/24.

For more information about CIDR * notation, see the Wikipedia entry Classless * Inter-Domain Routing.

Specify an IPv6 address by using CIDR notation. * For example:

  • To configure AWS WAF to allow, block, or count * requests that originated from the IP address * 1111:0000:0000:0000:0000:0000:0000:0111, specify * 1111:0000:0000:0000:0000:0000:0000:0111/128.

  • To * configure AWS WAF to allow, block, or count requests that originated from IP * addresses 1111:0000:0000:0000:0000:0000:0000:0000 to * 1111:0000:0000:0000:ffff:ffff:ffff:ffff, specify * 1111:0000:0000:0000:0000:0000:0000:0000/64.

*/ inline void SetValue(const char* value) { m_valueHasBeenSet = true; m_value.assign(value); } /** *

Specify an IPv4 address by using CIDR notation. For example:

  • *

    To configure AWS WAF to allow, block, or count requests that originated from * the IP address 192.0.2.44, specify 192.0.2.44/32.

  • *

    To configure AWS WAF to allow, block, or count requests that originated from * IP addresses from 192.0.2.0 to 192.0.2.255, specify * 192.0.2.0/24.

For more information about CIDR * notation, see the Wikipedia entry Classless * Inter-Domain Routing.

Specify an IPv6 address by using CIDR notation. * For example:

  • To configure AWS WAF to allow, block, or count * requests that originated from the IP address * 1111:0000:0000:0000:0000:0000:0000:0111, specify * 1111:0000:0000:0000:0000:0000:0000:0111/128.

  • To * configure AWS WAF to allow, block, or count requests that originated from IP * addresses 1111:0000:0000:0000:0000:0000:0000:0000 to * 1111:0000:0000:0000:ffff:ffff:ffff:ffff, specify * 1111:0000:0000:0000:0000:0000:0000:0000/64.

*/ inline IPSetDescriptor& WithValue(const Aws::String& value) { SetValue(value); return *this;} /** *

Specify an IPv4 address by using CIDR notation. For example:

  • *

    To configure AWS WAF to allow, block, or count requests that originated from * the IP address 192.0.2.44, specify 192.0.2.44/32.

  • *

    To configure AWS WAF to allow, block, or count requests that originated from * IP addresses from 192.0.2.0 to 192.0.2.255, specify * 192.0.2.0/24.

For more information about CIDR * notation, see the Wikipedia entry Classless * Inter-Domain Routing.

Specify an IPv6 address by using CIDR notation. * For example:

  • To configure AWS WAF to allow, block, or count * requests that originated from the IP address * 1111:0000:0000:0000:0000:0000:0000:0111, specify * 1111:0000:0000:0000:0000:0000:0000:0111/128.

  • To * configure AWS WAF to allow, block, or count requests that originated from IP * addresses 1111:0000:0000:0000:0000:0000:0000:0000 to * 1111:0000:0000:0000:ffff:ffff:ffff:ffff, specify * 1111:0000:0000:0000:0000:0000:0000:0000/64.

*/ inline IPSetDescriptor& WithValue(Aws::String&& value) { SetValue(std::move(value)); return *this;} /** *

Specify an IPv4 address by using CIDR notation. For example:

  • *

    To configure AWS WAF to allow, block, or count requests that originated from * the IP address 192.0.2.44, specify 192.0.2.44/32.

  • *

    To configure AWS WAF to allow, block, or count requests that originated from * IP addresses from 192.0.2.0 to 192.0.2.255, specify * 192.0.2.0/24.

For more information about CIDR * notation, see the Wikipedia entry Classless * Inter-Domain Routing.

Specify an IPv6 address by using CIDR notation. * For example:

  • To configure AWS WAF to allow, block, or count * requests that originated from the IP address * 1111:0000:0000:0000:0000:0000:0000:0111, specify * 1111:0000:0000:0000:0000:0000:0000:0111/128.

  • To * configure AWS WAF to allow, block, or count requests that originated from IP * addresses 1111:0000:0000:0000:0000:0000:0000:0000 to * 1111:0000:0000:0000:ffff:ffff:ffff:ffff, specify * 1111:0000:0000:0000:0000:0000:0000:0000/64.

*/ inline IPSetDescriptor& WithValue(const char* value) { SetValue(value); return *this;} private: IPSetDescriptorType m_type; bool m_typeHasBeenSet = false; Aws::String m_value; bool m_valueHasBeenSet = false; }; } // namespace Model } // namespace WAF } // namespace Aws