interface StatementProperty
| Language | Type name | 
|---|---|
|  .NET | Amazon.CDK.AWS.WAFv2.CfnRuleGroup.StatementProperty | 
|  Java | software.amazon.awscdk.services.wafv2.CfnRuleGroup.StatementProperty | 
|  Python | aws_cdk.aws_wafv2.CfnRuleGroup.StatementProperty | 
|  TypeScript | @aws-cdk/aws-wafv2»CfnRuleGroup»StatementProperty | 
The processing guidance for a rule, used by AWS WAF to determine whether a web request matches the rule.
Example
// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import * as wafv2 from '@aws-cdk/aws-wafv2';
declare const all: any;
declare const allQueryArguments: any;
declare const andStatementProperty_: wafv2.CfnRuleGroup.AndStatementProperty;
declare const method: any;
declare const notStatementProperty_: wafv2.CfnRuleGroup.NotStatementProperty;
declare const orStatementProperty_: wafv2.CfnRuleGroup.OrStatementProperty;
declare const queryString: any;
declare const rateBasedStatementProperty_: wafv2.CfnRuleGroup.RateBasedStatementProperty;
declare const singleHeader: any;
declare const singleQueryArgument: any;
declare const statementProperty_: wafv2.CfnRuleGroup.StatementProperty;
declare const uriPath: any;
const statementProperty: wafv2.CfnRuleGroup.StatementProperty = {
  andStatement: {
    statements: [{
      andStatement: andStatementProperty_,
      byteMatchStatement: {
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        positionalConstraint: 'positionalConstraint',
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
        // the properties below are optional
        searchString: 'searchString',
        searchStringBase64: 'searchStringBase64',
      },
      geoMatchStatement: {
        countryCodes: ['countryCodes'],
        forwardedIpConfig: {
          fallbackBehavior: 'fallbackBehavior',
          headerName: 'headerName',
        },
      },
      ipSetReferenceStatement: {
        arn: 'arn',
        // the properties below are optional
        ipSetForwardedIpConfig: {
          fallbackBehavior: 'fallbackBehavior',
          headerName: 'headerName',
          position: 'position',
        },
      },
      labelMatchStatement: {
        key: 'key',
        scope: 'scope',
      },
      notStatement: {
        statement: statementProperty_,
      },
      orStatement: {
        statements: [statementProperty_],
      },
      rateBasedStatement: {
        aggregateKeyType: 'aggregateKeyType',
        limit: 123,
        // the properties below are optional
        forwardedIpConfig: {
          fallbackBehavior: 'fallbackBehavior',
          headerName: 'headerName',
        },
        scopeDownStatement: statementProperty_,
      },
      regexMatchStatement: {
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        regexString: 'regexString',
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
      },
      regexPatternSetReferenceStatement: {
        arn: 'arn',
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
      },
      sizeConstraintStatement: {
        comparisonOperator: 'comparisonOperator',
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        size: 123,
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
      },
      sqliMatchStatement: {
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
        // the properties below are optional
        sensitivityLevel: 'sensitivityLevel',
      },
      xssMatchStatement: {
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
      },
    }],
  },
  byteMatchStatement: {
    fieldToMatch: {
      allQueryArguments: allQueryArguments,
      body: {
        oversizeHandling: 'oversizeHandling',
      },
      cookies: {
        matchPattern: {
          all: all,
          excludedCookies: ['excludedCookies'],
          includedCookies: ['includedCookies'],
        },
        matchScope: 'matchScope',
        oversizeHandling: 'oversizeHandling',
      },
      headers: {
        matchPattern: {
          all: all,
          excludedHeaders: ['excludedHeaders'],
          includedHeaders: ['includedHeaders'],
        },
        matchScope: 'matchScope',
        oversizeHandling: 'oversizeHandling',
      },
      jsonBody: {
        matchPattern: {
          all: all,
          includedPaths: ['includedPaths'],
        },
        matchScope: 'matchScope',
        // the properties below are optional
        invalidFallbackBehavior: 'invalidFallbackBehavior',
        oversizeHandling: 'oversizeHandling',
      },
      method: method,
      queryString: queryString,
      singleHeader: singleHeader,
      singleQueryArgument: singleQueryArgument,
      uriPath: uriPath,
    },
    positionalConstraint: 'positionalConstraint',
    textTransformations: [{
      priority: 123,
      type: 'type',
    }],
    // the properties below are optional
    searchString: 'searchString',
    searchStringBase64: 'searchStringBase64',
  },
  geoMatchStatement: {
    countryCodes: ['countryCodes'],
    forwardedIpConfig: {
      fallbackBehavior: 'fallbackBehavior',
      headerName: 'headerName',
    },
  },
  ipSetReferenceStatement: {
    arn: 'arn',
    // the properties below are optional
    ipSetForwardedIpConfig: {
      fallbackBehavior: 'fallbackBehavior',
      headerName: 'headerName',
      position: 'position',
    },
  },
  labelMatchStatement: {
    key: 'key',
    scope: 'scope',
  },
  notStatement: {
    statement: {
      andStatement: {
        statements: [statementProperty_],
      },
      byteMatchStatement: {
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        positionalConstraint: 'positionalConstraint',
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
        // the properties below are optional
        searchString: 'searchString',
        searchStringBase64: 'searchStringBase64',
      },
      geoMatchStatement: {
        countryCodes: ['countryCodes'],
        forwardedIpConfig: {
          fallbackBehavior: 'fallbackBehavior',
          headerName: 'headerName',
        },
      },
      ipSetReferenceStatement: {
        arn: 'arn',
        // the properties below are optional
        ipSetForwardedIpConfig: {
          fallbackBehavior: 'fallbackBehavior',
          headerName: 'headerName',
          position: 'position',
        },
      },
      labelMatchStatement: {
        key: 'key',
        scope: 'scope',
      },
      notStatement: notStatementProperty_,
      orStatement: {
        statements: [statementProperty_],
      },
      rateBasedStatement: {
        aggregateKeyType: 'aggregateKeyType',
        limit: 123,
        // the properties below are optional
        forwardedIpConfig: {
          fallbackBehavior: 'fallbackBehavior',
          headerName: 'headerName',
        },
        scopeDownStatement: statementProperty_,
      },
      regexMatchStatement: {
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        regexString: 'regexString',
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
      },
      regexPatternSetReferenceStatement: {
        arn: 'arn',
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
      },
      sizeConstraintStatement: {
        comparisonOperator: 'comparisonOperator',
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        size: 123,
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
      },
      sqliMatchStatement: {
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
        // the properties below are optional
        sensitivityLevel: 'sensitivityLevel',
      },
      xssMatchStatement: {
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
      },
    },
  },
  orStatement: {
    statements: [{
      andStatement: {
        statements: [statementProperty_],
      },
      byteMatchStatement: {
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        positionalConstraint: 'positionalConstraint',
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
        // the properties below are optional
        searchString: 'searchString',
        searchStringBase64: 'searchStringBase64',
      },
      geoMatchStatement: {
        countryCodes: ['countryCodes'],
        forwardedIpConfig: {
          fallbackBehavior: 'fallbackBehavior',
          headerName: 'headerName',
        },
      },
      ipSetReferenceStatement: {
        arn: 'arn',
        // the properties below are optional
        ipSetForwardedIpConfig: {
          fallbackBehavior: 'fallbackBehavior',
          headerName: 'headerName',
          position: 'position',
        },
      },
      labelMatchStatement: {
        key: 'key',
        scope: 'scope',
      },
      notStatement: {
        statement: statementProperty_,
      },
      orStatement: orStatementProperty_,
      rateBasedStatement: {
        aggregateKeyType: 'aggregateKeyType',
        limit: 123,
        // the properties below are optional
        forwardedIpConfig: {
          fallbackBehavior: 'fallbackBehavior',
          headerName: 'headerName',
        },
        scopeDownStatement: statementProperty_,
      },
      regexMatchStatement: {
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        regexString: 'regexString',
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
      },
      regexPatternSetReferenceStatement: {
        arn: 'arn',
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
      },
      sizeConstraintStatement: {
        comparisonOperator: 'comparisonOperator',
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        size: 123,
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
      },
      sqliMatchStatement: {
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
        // the properties below are optional
        sensitivityLevel: 'sensitivityLevel',
      },
      xssMatchStatement: {
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
      },
    }],
  },
  rateBasedStatement: {
    aggregateKeyType: 'aggregateKeyType',
    limit: 123,
    // the properties below are optional
    forwardedIpConfig: {
      fallbackBehavior: 'fallbackBehavior',
      headerName: 'headerName',
    },
    scopeDownStatement: {
      andStatement: {
        statements: [statementProperty_],
      },
      byteMatchStatement: {
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        positionalConstraint: 'positionalConstraint',
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
        // the properties below are optional
        searchString: 'searchString',
        searchStringBase64: 'searchStringBase64',
      },
      geoMatchStatement: {
        countryCodes: ['countryCodes'],
        forwardedIpConfig: {
          fallbackBehavior: 'fallbackBehavior',
          headerName: 'headerName',
        },
      },
      ipSetReferenceStatement: {
        arn: 'arn',
        // the properties below are optional
        ipSetForwardedIpConfig: {
          fallbackBehavior: 'fallbackBehavior',
          headerName: 'headerName',
          position: 'position',
        },
      },
      labelMatchStatement: {
        key: 'key',
        scope: 'scope',
      },
      notStatement: {
        statement: statementProperty_,
      },
      orStatement: {
        statements: [statementProperty_],
      },
      rateBasedStatement: rateBasedStatementProperty_,
      regexMatchStatement: {
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        regexString: 'regexString',
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
      },
      regexPatternSetReferenceStatement: {
        arn: 'arn',
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
      },
      sizeConstraintStatement: {
        comparisonOperator: 'comparisonOperator',
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        size: 123,
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
      },
      sqliMatchStatement: {
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
        // the properties below are optional
        sensitivityLevel: 'sensitivityLevel',
      },
      xssMatchStatement: {
        fieldToMatch: {
          allQueryArguments: allQueryArguments,
          body: {
            oversizeHandling: 'oversizeHandling',
          },
          cookies: {
            matchPattern: {
              all: all,
              excludedCookies: ['excludedCookies'],
              includedCookies: ['includedCookies'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          headers: {
            matchPattern: {
              all: all,
              excludedHeaders: ['excludedHeaders'],
              includedHeaders: ['includedHeaders'],
            },
            matchScope: 'matchScope',
            oversizeHandling: 'oversizeHandling',
          },
          jsonBody: {
            matchPattern: {
              all: all,
              includedPaths: ['includedPaths'],
            },
            matchScope: 'matchScope',
            // the properties below are optional
            invalidFallbackBehavior: 'invalidFallbackBehavior',
            oversizeHandling: 'oversizeHandling',
          },
          method: method,
          queryString: queryString,
          singleHeader: singleHeader,
          singleQueryArgument: singleQueryArgument,
          uriPath: uriPath,
        },
        textTransformations: [{
          priority: 123,
          type: 'type',
        }],
      },
    },
  },
  regexMatchStatement: {
    fieldToMatch: {
      allQueryArguments: allQueryArguments,
      body: {
        oversizeHandling: 'oversizeHandling',
      },
      cookies: {
        matchPattern: {
          all: all,
          excludedCookies: ['excludedCookies'],
          includedCookies: ['includedCookies'],
        },
        matchScope: 'matchScope',
        oversizeHandling: 'oversizeHandling',
      },
      headers: {
        matchPattern: {
          all: all,
          excludedHeaders: ['excludedHeaders'],
          includedHeaders: ['includedHeaders'],
        },
        matchScope: 'matchScope',
        oversizeHandling: 'oversizeHandling',
      },
      jsonBody: {
        matchPattern: {
          all: all,
          includedPaths: ['includedPaths'],
        },
        matchScope: 'matchScope',
        // the properties below are optional
        invalidFallbackBehavior: 'invalidFallbackBehavior',
        oversizeHandling: 'oversizeHandling',
      },
      method: method,
      queryString: queryString,
      singleHeader: singleHeader,
      singleQueryArgument: singleQueryArgument,
      uriPath: uriPath,
    },
    regexString: 'regexString',
    textTransformations: [{
      priority: 123,
      type: 'type',
    }],
  },
  regexPatternSetReferenceStatement: {
    arn: 'arn',
    fieldToMatch: {
      allQueryArguments: allQueryArguments,
      body: {
        oversizeHandling: 'oversizeHandling',
      },
      cookies: {
        matchPattern: {
          all: all,
          excludedCookies: ['excludedCookies'],
          includedCookies: ['includedCookies'],
        },
        matchScope: 'matchScope',
        oversizeHandling: 'oversizeHandling',
      },
      headers: {
        matchPattern: {
          all: all,
          excludedHeaders: ['excludedHeaders'],
          includedHeaders: ['includedHeaders'],
        },
        matchScope: 'matchScope',
        oversizeHandling: 'oversizeHandling',
      },
      jsonBody: {
        matchPattern: {
          all: all,
          includedPaths: ['includedPaths'],
        },
        matchScope: 'matchScope',
        // the properties below are optional
        invalidFallbackBehavior: 'invalidFallbackBehavior',
        oversizeHandling: 'oversizeHandling',
      },
      method: method,
      queryString: queryString,
      singleHeader: singleHeader,
      singleQueryArgument: singleQueryArgument,
      uriPath: uriPath,
    },
    textTransformations: [{
      priority: 123,
      type: 'type',
    }],
  },
  sizeConstraintStatement: {
    comparisonOperator: 'comparisonOperator',
    fieldToMatch: {
      allQueryArguments: allQueryArguments,
      body: {
        oversizeHandling: 'oversizeHandling',
      },
      cookies: {
        matchPattern: {
          all: all,
          excludedCookies: ['excludedCookies'],
          includedCookies: ['includedCookies'],
        },
        matchScope: 'matchScope',
        oversizeHandling: 'oversizeHandling',
      },
      headers: {
        matchPattern: {
          all: all,
          excludedHeaders: ['excludedHeaders'],
          includedHeaders: ['includedHeaders'],
        },
        matchScope: 'matchScope',
        oversizeHandling: 'oversizeHandling',
      },
      jsonBody: {
        matchPattern: {
          all: all,
          includedPaths: ['includedPaths'],
        },
        matchScope: 'matchScope',
        // the properties below are optional
        invalidFallbackBehavior: 'invalidFallbackBehavior',
        oversizeHandling: 'oversizeHandling',
      },
      method: method,
      queryString: queryString,
      singleHeader: singleHeader,
      singleQueryArgument: singleQueryArgument,
      uriPath: uriPath,
    },
    size: 123,
    textTransformations: [{
      priority: 123,
      type: 'type',
    }],
  },
  sqliMatchStatement: {
    fieldToMatch: {
      allQueryArguments: allQueryArguments,
      body: {
        oversizeHandling: 'oversizeHandling',
      },
      cookies: {
        matchPattern: {
          all: all,
          excludedCookies: ['excludedCookies'],
          includedCookies: ['includedCookies'],
        },
        matchScope: 'matchScope',
        oversizeHandling: 'oversizeHandling',
      },
      headers: {
        matchPattern: {
          all: all,
          excludedHeaders: ['excludedHeaders'],
          includedHeaders: ['includedHeaders'],
        },
        matchScope: 'matchScope',
        oversizeHandling: 'oversizeHandling',
      },
      jsonBody: {
        matchPattern: {
          all: all,
          includedPaths: ['includedPaths'],
        },
        matchScope: 'matchScope',
        // the properties below are optional
        invalidFallbackBehavior: 'invalidFallbackBehavior',
        oversizeHandling: 'oversizeHandling',
      },
      method: method,
      queryString: queryString,
      singleHeader: singleHeader,
      singleQueryArgument: singleQueryArgument,
      uriPath: uriPath,
    },
    textTransformations: [{
      priority: 123,
      type: 'type',
    }],
    // the properties below are optional
    sensitivityLevel: 'sensitivityLevel',
  },
  xssMatchStatement: {
    fieldToMatch: {
      allQueryArguments: allQueryArguments,
      body: {
        oversizeHandling: 'oversizeHandling',
      },
      cookies: {
        matchPattern: {
          all: all,
          excludedCookies: ['excludedCookies'],
          includedCookies: ['includedCookies'],
        },
        matchScope: 'matchScope',
        oversizeHandling: 'oversizeHandling',
      },
      headers: {
        matchPattern: {
          all: all,
          excludedHeaders: ['excludedHeaders'],
          includedHeaders: ['includedHeaders'],
        },
        matchScope: 'matchScope',
        oversizeHandling: 'oversizeHandling',
      },
      jsonBody: {
        matchPattern: {
          all: all,
          includedPaths: ['includedPaths'],
        },
        matchScope: 'matchScope',
        // the properties below are optional
        invalidFallbackBehavior: 'invalidFallbackBehavior',
        oversizeHandling: 'oversizeHandling',
      },
      method: method,
      queryString: queryString,
      singleHeader: singleHeader,
      singleQueryArgument: singleQueryArgument,
      uriPath: uriPath,
    },
    textTransformations: [{
      priority: 123,
      type: 'type',
    }],
  },
};
Properties
| Name | Type | Description | 
|---|---|---|
| and | IResolvable | And | A logical rule statement used to combine other rule statements with AND logic. | 
| byte | IResolvable | Byte | A rule statement that defines a string match search for AWS WAF to apply to web requests. | 
| geo | IResolvable | Geo | A rule statement that labels web requests by country and region and that matches against web requests based on country code. | 
| ip | IResolvable | IPSet | A rule statement used to detect web requests coming from particular IP addresses or address ranges. | 
| label | IResolvable | Label | 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. | 
| not | IResolvable | Not | A logical rule statement used to negate the results of another rule statement. | 
| or | IResolvable | Or | A logical rule statement used to combine other rule statements with OR logic. | 
| rate | IResolvable | Rate | A rate-based rule tracks the rate of requests for each originating IP address, and triggers the rule action when the rate exceeds a limit that you specify on the number of requests in any 5-minute time span. | 
| regex | IResolvable | Regex | A rule statement used to search web request components for a match against a single regular expression. | 
| regex | IResolvable | Regex | A rule statement used to search web request components for matches with regular expressions. | 
| size | IResolvable | Size | 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 (<). | 
| sqli | IResolvable | Sqli | A rule statement that inspects for malicious SQL code. | 
| xss | IResolvable | Xss | A rule statement that inspects for cross-site scripting (XSS) attacks. | 
andStatement?
Type:
IResolvable | And
(optional)
A logical rule statement used to combine other rule statements with AND logic.
You provide more than one Statement within the AndStatement .
byteMatchStatement?
Type:
IResolvable | Byte
(optional)
A rule statement that defines a string match search for AWS WAF to apply to web requests.
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?
Type:
IResolvable | Geo
(optional)
A rule statement that labels web requests by country and region and that matches against web requests based on country code.
A geo match rule labels every request that it inspects regardless of whether it finds a match.
- To manage requests only by country, you can use this statement by itself and specify the countries that you want to match against in the CountryCodesarray.
- Otherwise, configure your geo match rule with Count action so that it only labels requests. Then, add one or more label match rules to run after the geo match rule and configure them to match against the geographic labels and handle the requests as needed.
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?
Type:
IResolvable | IPSet
(optional)
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.
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?
Type:
IResolvable | Label
(optional)
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.
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.
notStatement?
Type:
IResolvable | Not
(optional)
A logical rule statement used to negate the results of another rule statement.
You provide one Statement within the NotStatement .
orStatement?
Type:
IResolvable | Or
(optional)
A logical rule statement used to combine other rule statements with OR logic.
You provide more than one Statement within the OrStatement .
rateBasedStatement?
Type:
IResolvable | Rate
(optional)
A rate-based rule tracks the rate of requests for each originating IP address, and triggers the rule action when the rate exceeds a limit that you specify on the number of requests in any 5-minute time span.
You can use this to put a temporary block on requests from an IP address that is sending excessive requests.
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 .
When the rule action triggers, AWS WAF blocks additional requests from the IP address until the request rate falls below the limit.
You can optionally nest another statement inside the rate-based statement, to narrow the scope of the rule so that it only counts requests that match the nested statement. For example, based on recent requests that you have seen from an attacker, you might create a rate-based rule with a nested AND rule statement that contains the following nested statements:
- An IP match statement with an IP set that specifies the address 192.0.2.44.
- A string match statement that searches in the User-Agent header for the string BadBot.
In this rate-based rule, you also define a rate limit. For this example, the rate limit is 1,000. Requests that meet the criteria of both of the nested statements are counted. If the count exceeds 1,000 requests per five minutes, the rule action triggers. Requests that do not meet the criteria of both of the nested statements are not counted towards the rate limit and are not affected by this 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.
regexMatchStatement?
Type:
IResolvable | Regex
(optional)
A rule statement used to search web request components for a match against a single regular expression.
regexPatternSetReferenceStatement?
Type:
IResolvable | Regex
(optional)
A rule statement used to search web request components for matches with regular expressions.
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.
sizeConstraintStatement?
Type:
IResolvable | Size
(optional)
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 (<).
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 of the body up to the limit for the web ACL. By default, for regional web ACLs, this limit is 8 KB (8,192 kilobytes) and for CloudFront web ACLs, this limit is 16 KB (16,384 kilobytes). For CloudFront web ACLs, you can increase the limit in the web ACL AssociationConfig , for additional fees. If you know that the request body for your web requests should never exceed the inspection limit, you could use a size constraint statement to block requests that have a larger request body size.
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?
Type:
IResolvable | Sqli
(optional)
A rule statement that inspects for malicious SQL code.
Attackers insert malicious SQL code into web requests to do things like modify your database or extract data from it.
xssMatchStatement?
Type:
IResolvable | Xss
(optional)
A rule statement that inspects for cross-site scripting (XSS) attacks.
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.
