/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
* SPDX-License-Identifier: Apache-2.0.
*/
#pragma once
#include A rule statement used to detect web requests coming from particular IP
* addresses or address ranges. To use this, create an IPSet that specifies
* the addresses you want to detect, then use the ARN of that set in this
* statement. To create an IP set, see CreateIPSet. Each IP set rule
* statement references an IP set. You create and maintain the set independent of
* your rules. This allows you to use the single set in multiple rules. When you
* update the referenced set, WAF automatically updates all rules that reference
* it.See Also:
AWS
* API Reference
The Amazon Resource Name (ARN) of the IPSet that this statement * references.
*/ inline const Aws::String& GetARN() const{ return m_aRN; } /** *The Amazon Resource Name (ARN) of the IPSet that this statement * references.
*/ inline bool ARNHasBeenSet() const { return m_aRNHasBeenSet; } /** *The Amazon Resource Name (ARN) of the IPSet that this statement * references.
*/ inline void SetARN(const Aws::String& value) { m_aRNHasBeenSet = true; m_aRN = value; } /** *The Amazon Resource Name (ARN) of the IPSet that this statement * references.
*/ inline void SetARN(Aws::String&& value) { m_aRNHasBeenSet = true; m_aRN = std::move(value); } /** *The Amazon Resource Name (ARN) of the IPSet that this statement * references.
*/ inline void SetARN(const char* value) { m_aRNHasBeenSet = true; m_aRN.assign(value); } /** *The Amazon Resource Name (ARN) of the IPSet that this statement * references.
*/ inline IPSetReferenceStatement& WithARN(const Aws::String& value) { SetARN(value); return *this;} /** *The Amazon Resource Name (ARN) of the IPSet that this statement * references.
*/ inline IPSetReferenceStatement& WithARN(Aws::String&& value) { SetARN(std::move(value)); return *this;} /** *The Amazon Resource Name (ARN) of the IPSet that this statement * references.
*/ inline IPSetReferenceStatement& WithARN(const char* value) { SetARN(value); return *this;} /** *The configuration for inspecting IP addresses in an HTTP header that you * specify, instead of using the IP address that's reported by the web request * origin. Commonly, this is the X-Forwarded-For (XFF) header, but you can specify * any header name.
If the specified header isn't present in the * request, WAF doesn't apply the rule to the web request at all.
*/ inline const IPSetForwardedIPConfig& GetIPSetForwardedIPConfig() const{ return m_iPSetForwardedIPConfig; } /** *The configuration for inspecting IP addresses in an HTTP header that you * specify, instead of using the IP address that's reported by the web request * origin. Commonly, this is the X-Forwarded-For (XFF) header, but you can specify * any header name.
If the specified header isn't present in the * request, WAF doesn't apply the rule to the web request at all.
*/ inline bool IPSetForwardedIPConfigHasBeenSet() const { return m_iPSetForwardedIPConfigHasBeenSet; } /** *The configuration for inspecting IP addresses in an HTTP header that you * specify, instead of using the IP address that's reported by the web request * origin. Commonly, this is the X-Forwarded-For (XFF) header, but you can specify * any header name.
If the specified header isn't present in the * request, WAF doesn't apply the rule to the web request at all.
*/ inline void SetIPSetForwardedIPConfig(const IPSetForwardedIPConfig& value) { m_iPSetForwardedIPConfigHasBeenSet = true; m_iPSetForwardedIPConfig = value; } /** *The configuration for inspecting IP addresses in an HTTP header that you * specify, instead of using the IP address that's reported by the web request * origin. Commonly, this is the X-Forwarded-For (XFF) header, but you can specify * any header name.
If the specified header isn't present in the * request, WAF doesn't apply the rule to the web request at all.
*/ inline void SetIPSetForwardedIPConfig(IPSetForwardedIPConfig&& value) { m_iPSetForwardedIPConfigHasBeenSet = true; m_iPSetForwardedIPConfig = std::move(value); } /** *The configuration for inspecting IP addresses in an HTTP header that you * specify, instead of using the IP address that's reported by the web request * origin. Commonly, this is the X-Forwarded-For (XFF) header, but you can specify * any header name.
If the specified header isn't present in the * request, WAF doesn't apply the rule to the web request at all.
*/ inline IPSetReferenceStatement& WithIPSetForwardedIPConfig(const IPSetForwardedIPConfig& value) { SetIPSetForwardedIPConfig(value); return *this;} /** *The configuration for inspecting IP addresses in an HTTP header that you * specify, instead of using the IP address that's reported by the web request * origin. Commonly, this is the X-Forwarded-For (XFF) header, but you can specify * any header name.
If the specified header isn't present in the * request, WAF doesn't apply the rule to the web request at all.
*/ inline IPSetReferenceStatement& WithIPSetForwardedIPConfig(IPSetForwardedIPConfig&& value) { SetIPSetForwardedIPConfig(std::move(value)); return *this;} private: Aws::String m_aRN; bool m_aRNHasBeenSet = false; IPSetForwardedIPConfig m_iPSetForwardedIPConfig; bool m_iPSetForwardedIPConfigHasBeenSet = false; }; } // namespace Model } // namespace WAFV2 } // namespace Aws