Class CfnWebACL.StatementProperty
The processing guidance for a rule, used by AWS WAF to determine whether a web request matches the rule.
Inheritance
Implements
Namespace: Amazon.CDK.AWS.WAFv2
Assembly: Amazon.CDK.Lib.dll
Syntax (csharp)
public class StatementProperty : Object, CfnWebACL.IStatementProperty
Syntax (vb)
Public Class StatementProperty
Inherits Object
Implements CfnWebACL.IStatementProperty
Remarks
ExampleMetadata: fixture=_generated
Synopsis
Constructors
StatementProperty() |
Properties
AndStatement | A logical rule statement used to combine other rule statements with AND logic. |
ByteMatchStatement | A rule statement that defines a string match search for AWS WAF to apply to web requests. |
GeoMatchStatement | A rule statement that labels web requests by country and region and that matches against web requests based on country code. |
IpSetReferenceStatement | A rule statement used to detect web requests coming from particular IP addresses or address ranges. |
LabelMatchStatement | A rule statement to match against labels that have been added to the web request by rules that have already run in the web ACL. |
ManagedRuleGroupStatement | A rule statement used to run the rules that are defined in a managed rule group. |
NotStatement | A logical rule statement used to negate the results of another rule statement. |
OrStatement | A logical rule statement used to combine other rule statements with OR logic. |
RateBasedStatement | A rate-based rule counts incoming requests and rate limits requests when they are coming at too fast a rate. |
RegexMatchStatement | A rule statement used to search web request components for a match against a single regular expression. |
RegexPatternSetReferenceStatement | A rule statement used to search web request components for matches with regular expressions. |
RuleGroupReferenceStatement | A rule statement used to run the rules that are defined in a |
SizeConstraintStatement | A rule statement that compares a number of bytes against the size of a request component, using a comparison operator, such as greater than (>) or less than (<). |
SqliMatchStatement | A rule statement that inspects for malicious SQL code. |
XssMatchStatement | A rule statement that inspects for cross-site scripting (XSS) attacks. |
Constructors
StatementProperty()
public StatementProperty()
Properties
AndStatement
A logical rule statement used to combine other rule statements with AND logic.
public object AndStatement { get; set; }
Property Value
System.Object
Remarks
You provide more than one Statement
within the AndStatement
.
ByteMatchStatement
A rule statement that defines a string match search for AWS WAF to apply to web requests.
public object ByteMatchStatement { get; set; }
Property Value
System.Object
Remarks
The byte match statement provides the bytes to search for, the location in requests that you want AWS WAF to search, and other settings. The bytes to search for are typically a string that corresponds with ASCII characters. In the AWS WAF console and the developer guide, this is called a string match statement.
GeoMatchStatement
A rule statement that labels web requests by country and region and that matches against web requests based on country code.
public object GeoMatchStatement { get; set; }
Property Value
System.Object
Remarks
A geo match rule labels every request that it inspects regardless of whether it finds a match.
AWS WAF labels requests using the alpha-2 country and region codes from the International Organization for Standardization (ISO) 3166 standard. AWS WAF determines the codes using either the IP address in the web request origin or, if you specify it, the address in the geo match ForwardedIPConfig
.
If you use the web request origin, the label formats are awswaf:clientip:geo:region:<ISO country code>-<ISO region code>
and awswaf:clientip:geo:country:<ISO country code>
.
If you use a forwarded IP address, the label formats are awswaf:forwardedip:geo:region:<ISO country code>-<ISO region code>
and awswaf:forwardedip:geo:country:<ISO country code>
.
For additional details, see Geographic match rule statement in the AWS WAF Developer Guide .
IpSetReferenceStatement
A rule statement used to detect web requests coming from particular IP addresses or address ranges.
public object IpSetReferenceStatement { get; set; }
Property Value
System.Object
Remarks
To use this, create an IPSet
that specifies the addresses you want to detect, then use the ARN of that set in this statement.
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, AWS WAF automatically updates all rules that reference it.
LabelMatchStatement
A rule statement to match against labels that have been added to the web request by rules that have already run in the web ACL.
public object LabelMatchStatement { get; set; }
Property Value
System.Object
Remarks
The label match statement provides the label or namespace string to search for. The label string can represent a part or all of the fully qualified label name that had been added to the web request. Fully qualified labels have a prefix, optional namespaces, and label name. The prefix identifies the rule group or web ACL context of the rule that added the label. If you do not provide the fully qualified name in your label match string, AWS WAF performs the search for labels that were added in the same context as the label match statement.
ManagedRuleGroupStatement
A rule statement used to run the rules that are defined in a managed rule group.
public object ManagedRuleGroupStatement { get; set; }
Property Value
System.Object
Remarks
To use this, provide the vendor name and the name of the rule group in this statement. You can retrieve the required names through the API call ListAvailableManagedRuleGroups
.
You cannot nest a ManagedRuleGroupStatement
, for example for use inside a NotStatement
or OrStatement
. It can only be referenced as a top-level statement within a rule.
You are charged additional fees when you use the AWS WAF Bot Control managed rule group AWSManagedRulesBotControlRuleSet
, the AWS WAF Fraud Control account takeover prevention (ATP) managed rule group AWSManagedRulesATPRuleSet
, or the AWS WAF Fraud Control account creation fraud prevention (ACFP) managed rule group AWSManagedRulesACFPRuleSet
. For more information, see AWS WAF Pricing .
NotStatement
A logical rule statement used to negate the results of another rule statement.
public object NotStatement { get; set; }
Property Value
System.Object
Remarks
You provide one Statement
within the NotStatement
.
OrStatement
A logical rule statement used to combine other rule statements with OR logic.
public object OrStatement { get; set; }
Property Value
System.Object
Remarks
You provide more than one Statement
within the OrStatement
.
RateBasedStatement
A rate-based rule counts incoming requests and rate limits requests when they are coming at too fast a rate.
public object RateBasedStatement { get; set; }
Property Value
System.Object
Remarks
The rule categorizes requests according to your aggregation criteria, collects them into aggregation instances, and counts and rate limits the requests for each instance.
If you change any of these settings in a rule that's currently in use, the change resets the rule's rate limiting counts. This can pause the rule's rate limiting activities for up to a minute.
You can specify individual aggregation keys, like IP address or HTTP method. You can also specify aggregation key combinations, like IP address and HTTP method, or HTTP method, query argument, and cookie.
Each unique set of values for the aggregation keys that you specify is a separate aggregation instance, with the value from each key contributing to the aggregation instance definition.
For example, assume the rule evaluates web requests with the following IP address and HTTP method values:
The rule would create different aggregation instances according to your aggregation criteria, for example:
For any n-tuple of aggregation keys, each unique combination of values for the keys defines a separate aggregation instance, which AWS WAF counts and rate-limits individually.
You can optionally nest another statement inside the rate-based statement, to narrow the scope of the rule so that it only counts and rate limits requests that match the nested statement. You can use this nested scope-down statement in conjunction with your aggregation key specifications or you can just count and rate limit all requests that match the scope-down statement, without additional aggregation. When you choose to just manage all requests that match a scope-down statement, the aggregation instance is singular for the rule.
You cannot nest a RateBasedStatement
inside another statement, for example inside a NotStatement
or OrStatement
. You can define a RateBasedStatement
inside a web ACL and inside a rule group.
For additional information about the options, see Rate limiting web requests using rate-based rules in the AWS WAF Developer Guide .
If you only aggregate on the individual IP address or forwarded IP address, you can retrieve the list of IP addresses that AWS WAF is currently rate limiting for a rule through the API call GetRateBasedStatementManagedKeys
. This option is not available for other aggregation configurations.
AWS WAF tracks and manages web requests separately for each instance of a rate-based rule that you use. For example, if you provide the same rate-based rule settings in two web ACLs, each of the two rule statements represents a separate instance of the rate-based rule and gets its own tracking and management by AWS WAF . If you define a rate-based rule inside a rule group, and then use that rule group in multiple places, each use creates a separate instance of the rate-based rule that gets its own tracking and management by AWS WAF .
RegexMatchStatement
A rule statement used to search web request components for a match against a single regular expression.
public object RegexMatchStatement { get; set; }
Property Value
System.Object
Remarks
RegexPatternSetReferenceStatement
A rule statement used to search web request components for matches with regular expressions.
public object RegexPatternSetReferenceStatement { get; set; }
Property Value
System.Object
Remarks
To use this, create a RegexPatternSet
that specifies the expressions that you want to detect, then use the ARN of that set in this statement. A web request matches the pattern set rule statement if the request component matches any of the patterns in the set.
Each regex pattern set rule statement references a regex pattern 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, AWS WAF automatically updates all rules that reference it.
RuleGroupReferenceStatement
A rule statement used to run the rules that are defined in a RuleGroup
.
public object RuleGroupReferenceStatement { get; set; }
Property Value
System.Object
Remarks
To use this, create a rule group with your rules, then provide the ARN of the rule group in this statement.
You cannot nest a RuleGroupReferenceStatement
, for example for use inside a NotStatement
or OrStatement
. You cannot use a rule group reference statement inside another rule group. You can only reference a rule group as a top-level statement within a rule that you define in a web ACL.
SizeConstraintStatement
A rule statement that compares a number of bytes against the size of a request component, using a comparison operator, such as greater than (>) or less than (<).
public object SizeConstraintStatement { get; set; }
Property Value
System.Object
Remarks
For example, you can use a size constraint statement to look for query strings that are longer than 100 bytes.
If you configure AWS WAF to inspect the request body, AWS WAF inspects only the number of bytes in the body up to the limit for the web ACL and protected resource type. If you know that the request body for your web requests should never exceed the inspection limit, you can use a size constraint statement to block requests that have a larger request body size. For more information about the inspection limits, see Body
and JsonBody
settings for the FieldToMatch
data type.
If you choose URI for the value of Part of the request to filter on, the slash (/) in the URI counts as one character. For example, the URI /logo.jpg
is nine characters long.
SqliMatchStatement
A rule statement that inspects for malicious SQL code.
public object SqliMatchStatement { get; set; }
Property Value
System.Object
Remarks
Attackers insert malicious SQL code into web requests to do things like modify your database or extract data from it.
XssMatchStatement
A rule statement that inspects for cross-site scripting (XSS) attacks.
public object XssMatchStatement { get; set; }
Property Value
System.Object
Remarks
In XSS attacks, the attacker uses vulnerabilities in a benign website as a vehicle to inject malicious client-site scripts into other legitimate web browsers.