# frozen_string_literal: true

# WARNING ABOUT GENERATED CODE
#
# This file is generated. See the contributing guide for more information:
# https://github.com/aws/aws-sdk-ruby/blob/version-3/CONTRIBUTING.md
#
# WARNING ABOUT GENERATED CODE

module Aws::WAFV2
  module Types

    # Information for a single API key.
    #
    # API keys are required for the integration of the CAPTCHA API in your
    # JavaScript client applications. The API lets you customize the
    # placement and characteristics of the CAPTCHA puzzle for your end
    # users. For more information about the CAPTCHA JavaScript integration,
    # see [WAF client application integration][1] in the *WAF Developer
    # Guide*.
    #
    #
    #
    # [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-application-integration.html
    #
    # @!attribute [rw] token_domains
    #   The token domains that are defined in this API key.
    #   @return [Array<String>]
    #
    # @!attribute [rw] api_key
    #   The generated, encrypted API key. You can copy this for use in your
    #   JavaScript CAPTCHA integration.
    #   @return [String]
    #
    # @!attribute [rw] creation_timestamp
    #   The date and time that the key was created.
    #   @return [Time]
    #
    # @!attribute [rw] version
    #   Internal value used by WAF to manage the key.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/APIKeySummary AWS API Documentation
    #
    class APIKeySummary < Struct.new(
      :token_domains,
      :api_key,
      :creation_timestamp,
      :version)
      SENSITIVE = []
      include Aws::Structure
    end

    # Details for your use of the account creation fraud prevention managed
    # rule group, `AWSManagedRulesACFPRuleSet`. This configuration is used
    # in `ManagedRuleGroupConfig`.
    #
    # @!attribute [rw] creation_path
    #   The path of the account creation endpoint for your application. This
    #   is the page on your website that accepts the completed registration
    #   form for a new user. This page must accept `POST` requests.
    #
    #   For example, for the URL `https://example.com/web/newaccount`, you
    #   would provide the path `/web/newaccount`. Account creation page
    #   paths that start with the path that you provide are considered a
    #   match. For example `/web/newaccount` matches the account creation
    #   paths `/web/newaccount`, `/web/newaccount/`, `/web/newaccountPage`,
    #   and `/web/newaccount/thisPage`, but doesn't match the path
    #   `/home/web/newaccount` or `/website/newaccount`.
    #   @return [String]
    #
    # @!attribute [rw] registration_page_path
    #   The path of the account registration endpoint for your application.
    #   This is the page on your website that presents the registration form
    #   to new users.
    #
    #   <note markdown="1"> This page must accept `GET` text/html requests.
    #
    #    </note>
    #
    #   For example, for the URL `https://example.com/web/registration`, you
    #   would provide the path `/web/registration`. Registration page paths
    #   that start with the path that you provide are considered a match.
    #   For example `/web/registration` matches the registration paths
    #   `/web/registration`, `/web/registration/`, `/web/registrationPage`,
    #   and `/web/registration/thisPage`, but doesn't match the path
    #   `/home/web/registration` or `/website/registration`.
    #   @return [String]
    #
    # @!attribute [rw] request_inspection
    #   The criteria for inspecting account creation requests, used by the
    #   ACFP rule group to validate and track account creation attempts.
    #   @return [Types::RequestInspectionACFP]
    #
    # @!attribute [rw] response_inspection
    #   The criteria for inspecting responses to account creation requests,
    #   used by the ACFP rule group to track account creation success rates.
    #
    #   <note markdown="1"> Response inspection is available only in web ACLs that protect
    #   Amazon CloudFront distributions.
    #
    #    </note>
    #
    #   The ACFP rule group evaluates the responses that your protected
    #   resources send back to client account creation attempts, keeping
    #   count of successful and failed attempts from each IP address and
    #   client session. Using this information, the rule group labels and
    #   mitigates requests from client sessions and IP addresses that have
    #   had too many successful account creation attempts in a short amount
    #   of time.
    #   @return [Types::ResponseInspection]
    #
    # @!attribute [rw] enable_regex_in_path
    #   Allow the use of regular expressions in the registration page path
    #   and the account creation path.
    #   @return [Boolean]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/AWSManagedRulesACFPRuleSet AWS API Documentation
    #
    class AWSManagedRulesACFPRuleSet < Struct.new(
      :creation_path,
      :registration_page_path,
      :request_inspection,
      :response_inspection,
      :enable_regex_in_path)
      SENSITIVE = []
      include Aws::Structure
    end

    # Details for your use of the account takeover prevention managed rule
    # group, `AWSManagedRulesATPRuleSet`. This configuration is used in
    # `ManagedRuleGroupConfig`.
    #
    # @!attribute [rw] login_path
    #   The path of the login endpoint for your application. For example,
    #   for the URL `https://example.com/web/login`, you would provide the
    #   path `/web/login`. Login paths that start with the path that you
    #   provide are considered a match. For example `/web/login` matches the
    #   login paths `/web/login`, `/web/login/`, `/web/loginPage`, and
    #   `/web/login/thisPage`, but doesn't match the login path
    #   `/home/web/login` or `/website/login`.
    #
    #   The rule group inspects only HTTP `POST` requests to your specified
    #   login endpoint.
    #   @return [String]
    #
    # @!attribute [rw] request_inspection
    #   The criteria for inspecting login requests, used by the ATP rule
    #   group to validate credentials usage.
    #   @return [Types::RequestInspection]
    #
    # @!attribute [rw] response_inspection
    #   The criteria for inspecting responses to login requests, used by the
    #   ATP rule group to track login failure rates.
    #
    #   <note markdown="1"> Response inspection is available only in web ACLs that protect
    #   Amazon CloudFront distributions.
    #
    #    </note>
    #
    #   The ATP rule group evaluates the responses that your protected
    #   resources send back to client login attempts, keeping count of
    #   successful and failed attempts for each IP address and client
    #   session. Using this information, the rule group labels and mitigates
    #   requests from client sessions and IP addresses that have had too
    #   many failed login attempts in a short amount of time.
    #   @return [Types::ResponseInspection]
    #
    # @!attribute [rw] enable_regex_in_path
    #   Allow the use of regular expressions in the login page path.
    #   @return [Boolean]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/AWSManagedRulesATPRuleSet AWS API Documentation
    #
    class AWSManagedRulesATPRuleSet < Struct.new(
      :login_path,
      :request_inspection,
      :response_inspection,
      :enable_regex_in_path)
      SENSITIVE = []
      include Aws::Structure
    end

    # Details for your use of the Bot Control managed rule group,
    # `AWSManagedRulesBotControlRuleSet`. This configuration is used in
    # `ManagedRuleGroupConfig`.
    #
    # @!attribute [rw] inspection_level
    #   The inspection level to use for the Bot Control rule group. The
    #   common level is the least expensive. The targeted level includes all
    #   common level rules and adds rules with more advanced inspection
    #   criteria. For details, see [WAF Bot Control rule group][1] in the
    #   *WAF Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/aws-managed-rule-groups-bot.html
    #   @return [String]
    #
    # @!attribute [rw] enable_machine_learning
    #   Applies only to the targeted inspection level.
    #
    #   Determines whether to use machine learning (ML) to analyze your web
    #   traffic for bot-related activity. Machine learning is required for
    #   the Bot Control rules `TGT_ML_CoordinatedActivityLow` and
    #   `TGT_ML_CoordinatedActivityMedium`, which inspect for anomalous
    #   behavior that might indicate distributed, coordinated bot activity.
    #
    #   For more information about this choice, see the listing for these
    #   rules in the table at [Bot Control rules listing][1] in the *WAF
    #   Developer Guide*.
    #
    #   Default: `TRUE`
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/aws-managed-rule-groups-bot.html#aws-managed-rule-groups-bot-rules
    #   @return [Boolean]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/AWSManagedRulesBotControlRuleSet AWS API Documentation
    #
    class AWSManagedRulesBotControlRuleSet < Struct.new(
      :inspection_level,
      :enable_machine_learning)
      SENSITIVE = []
      include Aws::Structure
    end

    # A single action condition for a Condition in a logging filter.
    #
    # @!attribute [rw] action
    #   The action setting that a log record must contain in order to meet
    #   the condition. This is the action that WAF applied to the web
    #   request.
    #
    #   For rule groups, this is either the configured rule action setting,
    #   or if you've applied a rule action override to the rule, it's the
    #   override action. The value `EXCLUDED_AS_COUNT` matches on excluded
    #   rules and also on rules that have a rule action override of Count.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ActionCondition AWS API Documentation
    #
    class ActionCondition < Struct.new(
      :action)
      SENSITIVE = []
      include Aws::Structure
    end

    # The name of a field in the request payload that contains part or all
    # of your customer's primary physical address.
    #
    # This data type is used in the `RequestInspectionACFP` data type.
    #
    # @!attribute [rw] identifier
    #   The name of a single primary address field.
    #
    #   How you specify the address fields depends on the request inspection
    #   payload type.
    #
    #   * For JSON payloads, specify the field identifiers in JSON pointer
    #     syntax. For information about the JSON Pointer syntax, see the
    #     Internet Engineering Task Force (IETF) documentation [JavaScript
    #     Object Notation (JSON) Pointer][1].
    #
    #     For example, for the JSON payload `{ "form": {
    #     "primaryaddressline1": "THE_ADDRESS1", "primaryaddressline2":
    #     "THE_ADDRESS2", "primaryaddressline3": "THE_ADDRESS3" } }`, the
    #     address field idenfiers are `/form/primaryaddressline1`,
    #     `/form/primaryaddressline2`, and `/form/primaryaddressline3`.
    #
    #   * For form encoded payload types, use the HTML form names.
    #
    #     For example, for an HTML form with input elements named
    #     `primaryaddressline1`, `primaryaddressline2`, and
    #     `primaryaddressline3`, the address fields identifiers are
    #     `primaryaddressline1`, `primaryaddressline2`, and
    #     `primaryaddressline3`.
    #
    #
    #
    #   [1]: https://tools.ietf.org/html/rfc6901
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/AddressField AWS API Documentation
    #
    class AddressField < Struct.new(
      :identifier)
      SENSITIVE = []
      include Aws::Structure
    end

    # Inspect all of the elements that WAF has parsed and extracted from the
    # web request component that you've identified in your FieldToMatch
    # specifications.
    #
    # This is used in the FieldToMatch specification for some web request
    # component types.
    #
    # JSON specification: `"All": {}`
    #
    # @api private
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/All AWS API Documentation
    #
    class All < Aws::EmptyStructure; end

    # Inspect all query arguments of the web request.
    #
    # This is used in the FieldToMatch specification for some web request
    # component types.
    #
    # JSON specification: `"AllQueryArguments": {}`
    #
    # @api private
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/AllQueryArguments AWS API Documentation
    #
    class AllQueryArguments < Aws::EmptyStructure; end

    # Specifies that WAF should allow the request and optionally defines
    # additional custom handling for the request.
    #
    # This is used in the context of other settings, for example to specify
    # values for RuleAction and web ACL DefaultAction.
    #
    # @!attribute [rw] custom_request_handling
    #   Defines custom handling for the web request.
    #
    #   For information about customizing web requests and responses, see
    #   [Customizing web requests and responses in WAF][1] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html
    #   @return [Types::CustomRequestHandling]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/AllowAction AWS API Documentation
    #
    class AllowAction < Struct.new(
      :custom_request_handling)
      SENSITIVE = []
      include Aws::Structure
    end

    # A logical rule statement used to combine other rule statements with
    # AND logic. You provide more than one Statement within the
    # `AndStatement`.
    #
    # @!attribute [rw] statements
    #   The statements to combine with AND logic. You can use any statements
    #   that can be nested.
    #   @return [Array<Types::Statement>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/AndStatement AWS API Documentation
    #
    class AndStatement < Struct.new(
      :statements)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] web_acl_arn
    #   The Amazon Resource Name (ARN) of the web ACL that you want to
    #   associate with the resource.
    #   @return [String]
    #
    # @!attribute [rw] resource_arn
    #   The Amazon Resource Name (ARN) of the resource to associate with the
    #   web ACL.
    #
    #   The ARN must be in one of the following formats:
    #
    #   * For an Application Load Balancer:
    #     `arn:partition:elasticloadbalancing:region:account-id:loadbalancer/app/load-balancer-name/load-balancer-id
    #     `
    #
    #   * For an Amazon API Gateway REST API:
    #     `arn:partition:apigateway:region::/restapis/api-id/stages/stage-name
    #     `
    #
    #   * For an AppSync GraphQL API:
    #     `arn:partition:appsync:region:account-id:apis/GraphQLApiId `
    #
    #   * For an Amazon Cognito user pool:
    #     `arn:partition:cognito-idp:region:account-id:userpool/user-pool-id
    #     `
    #
    #   * For an App Runner service:
    #     `arn:partition:apprunner:region:account-id:service/apprunner-service-name/apprunner-service-id
    #     `
    #
    #   * For an Amazon Web Services Verified Access instance:
    #     `arn:partition:ec2:region:account-id:verified-access-instance/instance-id
    #     `
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/AssociateWebACLRequest AWS API Documentation
    #
    class AssociateWebACLRequest < Struct.new(
      :web_acl_arn,
      :resource_arn)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/AssociateWebACLResponse AWS API Documentation
    #
    class AssociateWebACLResponse < Aws::EmptyStructure; end

    # Specifies custom configurations for the associations between the web
    # ACL and protected resources.
    #
    # Use this to customize the maximum size of the request body that your
    # protected resources forward to WAF for inspection. You can customize
    # this setting for CloudFront, API Gateway, Amazon Cognito, App Runner,
    # or Verified Access resources. The default setting is 16 KB (16,384
    # bytes).
    #
    # <note markdown="1"> You are charged additional fees when your protected resources forward
    # body sizes that are larger than the default. For more information, see
    # [WAF Pricing][1].
    #
    #  </note>
    #
    # For Application Load Balancer and AppSync, the limit is fixed at 8 KB
    # (8,192 bytes).
    #
    #
    #
    # [1]: http://aws.amazon.com/waf/pricing/
    #
    # @!attribute [rw] request_body
    #   Customizes the maximum size of the request body that your protected
    #   CloudFront, API Gateway, Amazon Cognito, App Runner, and Verified
    #   Access resources forward to WAF for inspection. The default size is
    #   16 KB (16,384 bytes). You can change the setting for any of the
    #   available resource types.
    #
    #   <note markdown="1"> You are charged additional fees when your protected resources
    #   forward body sizes that are larger than the default. For more
    #   information, see [WAF Pricing][1].
    #
    #    </note>
    #
    #   Example JSON: ` { "API_GATEWAY": "KB_48", "APP_RUNNER_SERVICE":
    #   "KB_32" }`
    #
    #   For Application Load Balancer and AppSync, the limit is fixed at 8
    #   KB (8,192 bytes).
    #
    #
    #
    #   [1]: http://aws.amazon.com/waf/pricing/
    #   @return [Hash<String,Types::RequestBodyAssociatedResourceTypeConfig>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/AssociationConfig AWS API Documentation
    #
    class AssociationConfig < Struct.new(
      :request_body)
      SENSITIVE = []
      include Aws::Structure
    end

    # Specifies that WAF should block the request and optionally defines
    # additional custom handling for the response to the web request.
    #
    # This is used in the context of other settings, for example to specify
    # values for RuleAction and web ACL DefaultAction.
    #
    # @!attribute [rw] custom_response
    #   Defines a custom response for the web request.
    #
    #   For information about customizing web requests and responses, see
    #   [Customizing web requests and responses in WAF][1] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html
    #   @return [Types::CustomResponse]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/BlockAction AWS API Documentation
    #
    class BlockAction < Struct.new(
      :custom_response)
      SENSITIVE = []
      include Aws::Structure
    end

    # Inspect the body of the web request. The body immediately follows the
    # request headers.
    #
    # This is used to indicate the web request component to inspect, in the
    # FieldToMatch specification.
    #
    # @!attribute [rw] oversize_handling
    #   What WAF should do if the body is larger than WAF can inspect.
    #
    #   WAF does not support inspecting the entire contents of the web
    #   request body if the body exceeds the limit for the resource type.
    #   When a web request body is larger than the limit, the underlying
    #   host service only forwards the contents that are within the limit to
    #   WAF for inspection.
    #
    #   * For Application Load Balancer and AppSync, the limit is fixed at 8
    #     KB (8,192 bytes).
    #
    #   * For CloudFront, API Gateway, Amazon Cognito, App Runner, and
    #     Verified Access, the default limit is 16 KB (16,384 bytes), and
    #     you can increase the limit for each resource type in the web ACL
    #     `AssociationConfig`, for additional processing fees.
    #
    #   The options for oversize handling are the following:
    #
    #   * `CONTINUE` - Inspect the available body contents normally,
    #     according to the rule inspection criteria.
    #
    #   * `MATCH` - Treat the web request as matching the rule statement.
    #     WAF applies the rule action to the request.
    #
    #   * `NO_MATCH` - Treat the web request as not matching the rule
    #     statement.
    #
    #   You can combine the `MATCH` or `NO_MATCH` settings for oversize
    #   handling with your rule and web ACL action settings, so that you
    #   block any request whose body is over the limit.
    #
    #   Default: `CONTINUE`
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/Body AWS API Documentation
    #
    class Body < Struct.new(
      :oversize_handling)
      SENSITIVE = []
      include Aws::Structure
    end

    # A rule statement that defines a string match search for WAF to apply
    # to web requests. The byte match statement provides the bytes to search
    # for, the location in requests that you want WAF to search, and other
    # settings. The bytes to search for are typically a string that
    # corresponds with ASCII characters. In the WAF console and the
    # developer guide, this is called a string match statement.
    #
    # @!attribute [rw] search_string
    #   A string value that you want WAF to search for. WAF searches only in
    #   the part of web requests that you designate for inspection in
    #   FieldToMatch. The maximum length of the value is 200 bytes.
    #
    #   Valid values depend on the component that you specify for inspection
    #   in `FieldToMatch`:
    #
    #   * `Method`: The HTTP method that you want WAF to search for. This
    #     indicates the type of operation specified in the request.
    #
    #   * `UriPath`: The value that you want WAF to search for in the URI
    #     path, for example, `/images/daily-ad.jpg`.
    #
    #   * `JA3Fingerprint`: Available for use with Amazon CloudFront
    #     distributions and Application Load Balancers. Match against the
    #     request's JA3 fingerprint. The JA3 fingerprint is a 32-character
    #     hash derived from the TLS Client Hello of an incoming request.
    #     This fingerprint serves as a unique identifier for the client's
    #     TLS configuration. You can use this choice only with a string
    #     match `ByteMatchStatement` with the `PositionalConstraint` set to
    #     `EXACTLY`.
    #
    #     You can obtain the JA3 fingerprint for client requests from the
    #     web ACL logs. If WAF is able to calculate the fingerprint, it
    #     includes it in the logs. For information about the logging fields,
    #     see [Log fields][1] in the *WAF Developer Guide*.
    #
    #   * `HeaderOrder`: The list of header names to match for. WAF creates
    #     a string that contains the ordered list of header names, from the
    #     headers in the web request, and then matches against that string.
    #
    #   If `SearchString` includes alphabetic characters A-Z and a-z, note
    #   that the value is case sensitive.
    #
    #   **If you're using the WAF API**
    #
    #   Specify a base64-encoded version of the value. The maximum length of
    #   the value before you base64-encode it is 200 bytes.
    #
    #   For example, suppose the value of `Type` is `HEADER` and the value
    #   of `Data` is `User-Agent`. If you want to search the `User-Agent`
    #   header for the value `BadBot`, you base64-encode `BadBot` using MIME
    #   base64-encoding and include the resulting value, `QmFkQm90`, in the
    #   value of `SearchString`.
    #
    #   **If you're using the CLI or one of the Amazon Web Services SDKs**
    #
    #   The value that you want WAF to search for. The SDK automatically
    #   base64 encodes the value.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/logging-fields.html
    #   @return [String]
    #
    # @!attribute [rw] field_to_match
    #   The part of the web request that you want WAF to inspect.
    #   @return [Types::FieldToMatch]
    #
    # @!attribute [rw] text_transformations
    #   Text transformations eliminate some of the unusual formatting that
    #   attackers use in web requests in an effort to bypass detection. Text
    #   transformations are used in rule match statements, to transform the
    #   `FieldToMatch` request component before inspecting it, and they're
    #   used in rate-based rule statements, to transform request components
    #   before using them as custom aggregation keys. If you specify one or
    #   more transformations to apply, WAF performs all transformations on
    #   the specified content, starting from the lowest priority setting,
    #   and then uses the transformed component contents.
    #   @return [Array<Types::TextTransformation>]
    #
    # @!attribute [rw] positional_constraint
    #   The area within the portion of the web request that you want WAF to
    #   search for `SearchString`. Valid values include the following:
    #
    #   **CONTAINS**
    #
    #   The specified part of the web request must include the value of
    #   `SearchString`, but the location doesn't matter.
    #
    #   **CONTAINS\_WORD**
    #
    #   The specified part of the web request must include the value of
    #   `SearchString`, and `SearchString` must contain only alphanumeric
    #   characters or underscore (A-Z, a-z, 0-9, or \_). In addition,
    #   `SearchString` must be a word, which means that both of the
    #   following are true:
    #
    #   * `SearchString` is at the beginning of the specified part of the
    #     web request or is preceded by a character other than an
    #     alphanumeric character or underscore (\_). Examples include the
    #     value of a header and `;BadBot`.
    #
    #   * `SearchString` is at the end of the specified part of the web
    #     request or is followed by a character other than an alphanumeric
    #     character or underscore (\_), for example, `BadBot;` and
    #     `-BadBot;`.
    #
    #   **EXACTLY**
    #
    #   The value of the specified part of the web request must exactly
    #   match the value of `SearchString`.
    #
    #   **STARTS\_WITH**
    #
    #   The value of `SearchString` must appear at the beginning of the
    #   specified part of the web request.
    #
    #   **ENDS\_WITH**
    #
    #   The value of `SearchString` must appear at the end of the specified
    #   part of the web request.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ByteMatchStatement AWS API Documentation
    #
    class ByteMatchStatement < Struct.new(
      :search_string,
      :field_to_match,
      :text_transformations,
      :positional_constraint)
      SENSITIVE = []
      include Aws::Structure
    end

    # Specifies that WAF should run a `CAPTCHA` check against the request:
    #
    # * If the request includes a valid, unexpired `CAPTCHA` token, WAF
    #   applies any custom request handling and labels that you've
    #   configured and then allows the web request inspection to proceed to
    #   the next rule, similar to a `CountAction`.
    #
    # * If the request doesn't include a valid, unexpired token, WAF
    #   discontinues the web ACL evaluation of the request and blocks it
    #   from going to its intended destination.
    #
    #   WAF generates a response that it sends back to the client, which
    #   includes the following:
    #
    #   * The header `x-amzn-waf-action` with a value of `captcha`.
    #
    #   * The HTTP status code `405 Method Not Allowed`.
    #
    #   * If the request contains an `Accept` header with a value of
    #     `text/html`, the response includes a `CAPTCHA` JavaScript page
    #     interstitial.
    #
    # You can configure the expiration time in the `CaptchaConfig`
    # `ImmunityTimeProperty` setting at the rule and web ACL level. The rule
    # setting overrides the web ACL setting.
    #
    # This action option is available for rules. It isn't available for web
    # ACL default actions.
    #
    # @!attribute [rw] custom_request_handling
    #   Defines custom handling for the web request, used when the `CAPTCHA`
    #   inspection determines that the request's token is valid and
    #   unexpired.
    #
    #   For information about customizing web requests and responses, see
    #   [Customizing web requests and responses in WAF][1] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html
    #   @return [Types::CustomRequestHandling]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CaptchaAction AWS API Documentation
    #
    class CaptchaAction < Struct.new(
      :custom_request_handling)
      SENSITIVE = []
      include Aws::Structure
    end

    # Specifies how WAF should handle `CAPTCHA` evaluations. This is
    # available at the web ACL level and in each rule.
    #
    # @!attribute [rw] immunity_time_property
    #   Determines how long a `CAPTCHA` timestamp in the token remains valid
    #   after the client successfully solves a `CAPTCHA` puzzle.
    #   @return [Types::ImmunityTimeProperty]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CaptchaConfig AWS API Documentation
    #
    class CaptchaConfig < Struct.new(
      :immunity_time_property)
      SENSITIVE = []
      include Aws::Structure
    end

    # The result from the inspection of the web request for a valid
    # `CAPTCHA` token.
    #
    # @!attribute [rw] response_code
    #   The HTTP response code indicating the status of the `CAPTCHA` token
    #   in the web request. If the token is missing, invalid, or expired,
    #   this code is `405 Method Not Allowed`.
    #   @return [Integer]
    #
    # @!attribute [rw] solve_timestamp
    #   The time that the `CAPTCHA` was last solved for the supplied token.
    #   @return [Integer]
    #
    # @!attribute [rw] failure_reason
    #   The reason for failure, populated when the evaluation of the token
    #   fails.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CaptchaResponse AWS API Documentation
    #
    class CaptchaResponse < Struct.new(
      :response_code,
      :solve_timestamp,
      :failure_reason)
      SENSITIVE = []
      include Aws::Structure
    end

    # Specifies that WAF should run a `Challenge` check against the request
    # to verify that the request is coming from a legitimate client session:
    #
    # * If the request includes a valid, unexpired challenge token, WAF
    #   applies any custom request handling and labels that you've
    #   configured and then allows the web request inspection to proceed to
    #   the next rule, similar to a `CountAction`.
    #
    # * If the request doesn't include a valid, unexpired challenge token,
    #   WAF discontinues the web ACL evaluation of the request and blocks it
    #   from going to its intended destination.
    #
    #   WAF then generates a challenge response that it sends back to the
    #   client, which includes the following:
    #
    #   * The header `x-amzn-waf-action` with a value of `challenge`.
    #
    #   * The HTTP status code `202 Request Accepted`.
    #
    #   * If the request contains an `Accept` header with a value of
    #     `text/html`, the response includes a JavaScript page interstitial
    #     with a challenge script.
    #   Challenges run silent browser interrogations in the background, and
    #   don't generally affect the end user experience.
    #
    #   A challenge enforces token acquisition using an interstitial
    #   JavaScript challenge that inspects the client session for legitimate
    #   behavior. The challenge blocks bots or at least increases the cost
    #   of operating sophisticated bots.
    #
    #   After the client session successfully responds to the challenge, it
    #   receives a new token from WAF, which the challenge script uses to
    #   resubmit the original request.
    #
    # You can configure the expiration time in the `ChallengeConfig`
    # `ImmunityTimeProperty` setting at the rule and web ACL level. The rule
    # setting overrides the web ACL setting.
    #
    # This action option is available for rules. It isn't available for web
    # ACL default actions.
    #
    # @!attribute [rw] custom_request_handling
    #   Defines custom handling for the web request, used when the challenge
    #   inspection determines that the request's token is valid and
    #   unexpired.
    #
    #   For information about customizing web requests and responses, see
    #   [Customizing web requests and responses in WAF][1] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html
    #   @return [Types::CustomRequestHandling]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ChallengeAction AWS API Documentation
    #
    class ChallengeAction < Struct.new(
      :custom_request_handling)
      SENSITIVE = []
      include Aws::Structure
    end

    # Specifies how WAF should handle `Challenge` evaluations. This is
    # available at the web ACL level and in each rule.
    #
    # @!attribute [rw] immunity_time_property
    #   Determines how long a challenge timestamp in the token remains valid
    #   after the client successfully responds to a challenge.
    #   @return [Types::ImmunityTimeProperty]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ChallengeConfig AWS API Documentation
    #
    class ChallengeConfig < Struct.new(
      :immunity_time_property)
      SENSITIVE = []
      include Aws::Structure
    end

    # The result from the inspection of the web request for a valid
    # challenge token.
    #
    # @!attribute [rw] response_code
    #   The HTTP response code indicating the status of the challenge token
    #   in the web request. If the token is missing, invalid, or expired,
    #   this code is `202 Request Accepted`.
    #   @return [Integer]
    #
    # @!attribute [rw] solve_timestamp
    #   The time that the challenge was last solved for the supplied token.
    #   @return [Integer]
    #
    # @!attribute [rw] failure_reason
    #   The reason for failure, populated when the evaluation of the token
    #   fails.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ChallengeResponse AWS API Documentation
    #
    class ChallengeResponse < Struct.new(
      :response_code,
      :solve_timestamp,
      :failure_reason)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] rules
    #   An array of Rule that you're configuring to use in a rule group or
    #   web ACL.
    #   @return [Array<Types::Rule>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CheckCapacityRequest AWS API Documentation
    #
    class CheckCapacityRequest < Struct.new(
      :scope,
      :rules)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] capacity
    #   The capacity required by the rules and scope.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CheckCapacityResponse AWS API Documentation
    #
    class CheckCapacityResponse < Struct.new(
      :capacity)
      SENSITIVE = []
      include Aws::Structure
    end

    # A single match condition for a Filter.
    #
    # @!attribute [rw] action_condition
    #   A single action condition. This is the action setting that a log
    #   record must contain in order to meet the condition.
    #   @return [Types::ActionCondition]
    #
    # @!attribute [rw] label_name_condition
    #   A single label name condition. This is the fully qualified label
    #   name that a log record must contain in order to meet the condition.
    #   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.
    #   @return [Types::LabelNameCondition]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/Condition AWS API Documentation
    #
    class Condition < Struct.new(
      :action_condition,
      :label_name_condition)
      SENSITIVE = []
      include Aws::Structure
    end

    # The filter to use to identify the subset of cookies to inspect in a
    # web request.
    #
    # You must specify exactly one setting: either `All`, `IncludedCookies`,
    # or `ExcludedCookies`.
    #
    # Example JSON: `"MatchPattern": { "IncludedCookies": [
    # "session-id-time", "session-id" ] }`
    #
    # @!attribute [rw] all
    #   Inspect all cookies.
    #   @return [Types::All]
    #
    # @!attribute [rw] included_cookies
    #   Inspect only the cookies that have a key that matches one of the
    #   strings specified here.
    #   @return [Array<String>]
    #
    # @!attribute [rw] excluded_cookies
    #   Inspect only the cookies whose keys don't match any of the strings
    #   specified here.
    #   @return [Array<String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CookieMatchPattern AWS API Documentation
    #
    class CookieMatchPattern < Struct.new(
      :all,
      :included_cookies,
      :excluded_cookies)
      SENSITIVE = []
      include Aws::Structure
    end

    # Inspect the cookies in the web request. You can specify the parts of
    # the cookies to inspect and you can narrow the set of cookies to
    # inspect by including or excluding specific keys.
    #
    # This is used to indicate the web request component to inspect, in the
    # FieldToMatch specification.
    #
    # Example JSON: `"Cookies": { "MatchPattern": { "All": {} },
    # "MatchScope": "KEY", "OversizeHandling": "MATCH" }`
    #
    # @!attribute [rw] match_pattern
    #   The filter to use to identify the subset of cookies to inspect in a
    #   web request.
    #
    #   You must specify exactly one setting: either `All`,
    #   `IncludedCookies`, or `ExcludedCookies`.
    #
    #   Example JSON: `"MatchPattern": { "IncludedCookies": [
    #   "session-id-time", "session-id" ] }`
    #   @return [Types::CookieMatchPattern]
    #
    # @!attribute [rw] match_scope
    #   The parts of the cookies to inspect with the rule inspection
    #   criteria. If you specify `ALL`, WAF inspects both keys and values.
    #
    #   `All` does not require a match to be found in the keys and a match
    #   to be found in the values. It requires a match to be found in the
    #   keys or the values or both. To require a match in the keys and in
    #   the values, use a logical `AND` statement to combine two match
    #   rules, one that inspects the keys and another that inspects the
    #   values.
    #   @return [String]
    #
    # @!attribute [rw] oversize_handling
    #   What WAF should do if the cookies of the request are more numerous
    #   or larger than WAF can inspect. WAF does not support inspecting the
    #   entire contents of request cookies when they exceed 8 KB (8192
    #   bytes) or 200 total cookies. The underlying host service forwards a
    #   maximum of 200 cookies and at most 8 KB of cookie contents to WAF.
    #
    #   The options for oversize handling are the following:
    #
    #   * `CONTINUE` - Inspect the available cookies normally, according to
    #     the rule inspection criteria.
    #
    #   * `MATCH` - Treat the web request as matching the rule statement.
    #     WAF applies the rule action to the request.
    #
    #   * `NO_MATCH` - Treat the web request as not matching the rule
    #     statement.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/Cookies AWS API Documentation
    #
    class Cookies < Struct.new(
      :match_pattern,
      :match_scope,
      :oversize_handling)
      SENSITIVE = []
      include Aws::Structure
    end

    # Specifies that WAF should count the request. Optionally defines
    # additional custom handling for the request.
    #
    # This is used in the context of other settings, for example to specify
    # values for RuleAction and web ACL DefaultAction.
    #
    # @!attribute [rw] custom_request_handling
    #   Defines custom handling for the web request.
    #
    #   For information about customizing web requests and responses, see
    #   [Customizing web requests and responses in WAF][1] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html
    #   @return [Types::CustomRequestHandling]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CountAction AWS API Documentation
    #
    class CountAction < Struct.new(
      :custom_request_handling)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] token_domains
    #   The client application domains that you want to use this API key
    #   for.
    #
    #   Example JSON: `"TokenDomains": ["abc.com", "store.abc.com"]`
    #
    #   Public suffixes aren't allowed. For example, you can't use
    #   `gov.au` or `co.uk` as token domains.
    #   @return [Array<String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CreateAPIKeyRequest AWS API Documentation
    #
    class CreateAPIKeyRequest < Struct.new(
      :scope,
      :token_domains)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] api_key
    #   The generated, encrypted API key. You can copy this for use in your
    #   JavaScript CAPTCHA integration.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CreateAPIKeyResponse AWS API Documentation
    #
    class CreateAPIKeyResponse < Struct.new(
      :api_key)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] name
    #   The name of the IP set. You cannot change the name of an `IPSet`
    #   after you create it.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   A description of the IP set that helps with identification.
    #   @return [String]
    #
    # @!attribute [rw] ip_address_version
    #   The version of the IP addresses, either `IPV4` or `IPV6`.
    #   @return [String]
    #
    # @!attribute [rw] addresses
    #   Contains an array of strings that specifies zero or more IP
    #   addresses or blocks of IP addresses that you want WAF to inspect for
    #   in incoming requests. All addresses must be specified using
    #   Classless Inter-Domain Routing (CIDR) notation. WAF supports all
    #   IPv4 and IPv6 CIDR ranges except for `/0`.
    #
    #   Example address strings:
    #
    #   * For requests that originated from the IP address 192.0.2.44,
    #     specify `192.0.2.44/32`.
    #
    #   * For requests that originated from IP addresses from 192.0.2.0 to
    #     192.0.2.255, specify `192.0.2.0/24`.
    #
    #   * For 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`.
    #
    #   * For 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`.
    #
    #   For more information about CIDR notation, see the Wikipedia entry
    #   [Classless Inter-Domain Routing][1].
    #
    #   Example JSON `Addresses` specifications:
    #
    #   * Empty array: `"Addresses": []`
    #
    #   * Array with one address: `"Addresses": ["192.0.2.44/32"]`
    #
    #   * Array with three addresses: `"Addresses": ["192.0.2.44/32",
    #     "192.0.2.0/24", "192.0.0.0/16"]`
    #
    #   * INVALID specification: `"Addresses": [""]` INVALID
    #
    #
    #
    #   [1]: https://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing
    #   @return [Array<String>]
    #
    # @!attribute [rw] tags
    #   An array of key:value pairs to associate with the resource.
    #   @return [Array<Types::Tag>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CreateIPSetRequest AWS API Documentation
    #
    class CreateIPSetRequest < Struct.new(
      :name,
      :scope,
      :description,
      :ip_address_version,
      :addresses,
      :tags)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] summary
    #   High-level information about an IPSet, returned by operations like
    #   create and list. This provides information like the ID, that you can
    #   use to retrieve and manage an `IPSet`, and the ARN, that you provide
    #   to the IPSetReferenceStatement to use the address set in a Rule.
    #   @return [Types::IPSetSummary]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CreateIPSetResponse AWS API Documentation
    #
    class CreateIPSetResponse < Struct.new(
      :summary)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] name
    #   The name of the set. You cannot change the name after you create the
    #   set.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   A description of the set that helps with identification.
    #   @return [String]
    #
    # @!attribute [rw] regular_expression_list
    #   Array of regular expression strings.
    #   @return [Array<Types::Regex>]
    #
    # @!attribute [rw] tags
    #   An array of key:value pairs to associate with the resource.
    #   @return [Array<Types::Tag>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CreateRegexPatternSetRequest AWS API Documentation
    #
    class CreateRegexPatternSetRequest < Struct.new(
      :name,
      :scope,
      :description,
      :regular_expression_list,
      :tags)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] summary
    #   High-level information about a RegexPatternSet, returned by
    #   operations like create and list. This provides information like the
    #   ID, that you can use to retrieve and manage a `RegexPatternSet`, and
    #   the ARN, that you provide to the RegexPatternSetReferenceStatement
    #   to use the pattern set in a Rule.
    #   @return [Types::RegexPatternSetSummary]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CreateRegexPatternSetResponse AWS API Documentation
    #
    class CreateRegexPatternSetResponse < Struct.new(
      :summary)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] name
    #   The name of the rule group. You cannot change the name of a rule
    #   group after you create it.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] capacity
    #   The web ACL capacity units (WCUs) required for this rule group.
    #
    #   When you create your own rule group, you define this, and you cannot
    #   change it after creation. When you add or modify the rules in a rule
    #   group, WAF enforces this limit. You can check the capacity for a set
    #   of rules using CheckCapacity.
    #
    #   WAF uses WCUs to calculate and control the operating resources that
    #   are used to run your rules, rule groups, and web ACLs. WAF
    #   calculates capacity differently for each rule type, to reflect the
    #   relative cost of each rule. Simple rules that cost little to run use
    #   fewer WCUs than more complex rules that use more processing power.
    #   Rule group capacity is fixed at creation, which helps users plan
    #   their web ACL WCU usage when they use a rule group. For more
    #   information, see [WAF web ACL capacity units (WCU)][1] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/aws-waf-capacity-units.html
    #   @return [Integer]
    #
    # @!attribute [rw] description
    #   A description of the rule group that helps with identification.
    #   @return [String]
    #
    # @!attribute [rw] rules
    #   The Rule statements used to identify the web requests that you want
    #   to manage. Each rule includes one top-level statement that WAF uses
    #   to identify matching web requests, and parameters that govern how
    #   WAF handles them.
    #   @return [Array<Types::Rule>]
    #
    # @!attribute [rw] visibility_config
    #   Defines and enables Amazon CloudWatch metrics and web request sample
    #   collection.
    #   @return [Types::VisibilityConfig]
    #
    # @!attribute [rw] tags
    #   An array of key:value pairs to associate with the resource.
    #   @return [Array<Types::Tag>]
    #
    # @!attribute [rw] custom_response_bodies
    #   A map of custom response keys and content bodies. When you create a
    #   rule with a block action, you can send a custom response to the web
    #   request. You define these for the rule group, and then use them in
    #   the rules that you define in the rule group.
    #
    #   For information about customizing web requests and responses, see
    #   [Customizing web requests and responses in WAF][1] in the *WAF
    #   Developer Guide*.
    #
    #   For information about the limits on count and size for custom
    #   request and response settings, see [WAF quotas][2] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html
    #   [2]: https://docs.aws.amazon.com/waf/latest/developerguide/limits.html
    #   @return [Hash<String,Types::CustomResponseBody>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CreateRuleGroupRequest AWS API Documentation
    #
    class CreateRuleGroupRequest < Struct.new(
      :name,
      :scope,
      :capacity,
      :description,
      :rules,
      :visibility_config,
      :tags,
      :custom_response_bodies)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] summary
    #   High-level information about a RuleGroup, returned by operations
    #   like create and list. This provides information like the ID, that
    #   you can use to retrieve and manage a `RuleGroup`, and the ARN, that
    #   you provide to the RuleGroupReferenceStatement to use the rule group
    #   in a Rule.
    #   @return [Types::RuleGroupSummary]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CreateRuleGroupResponse AWS API Documentation
    #
    class CreateRuleGroupResponse < Struct.new(
      :summary)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] name
    #   The name of the web ACL. You cannot change the name of a web ACL
    #   after you create it.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] default_action
    #   The action to perform if none of the `Rules` contained in the
    #   `WebACL` match.
    #   @return [Types::DefaultAction]
    #
    # @!attribute [rw] description
    #   A description of the web ACL that helps with identification.
    #   @return [String]
    #
    # @!attribute [rw] rules
    #   The Rule statements used to identify the web requests that you want
    #   to manage. Each rule includes one top-level statement that WAF uses
    #   to identify matching web requests, and parameters that govern how
    #   WAF handles them.
    #   @return [Array<Types::Rule>]
    #
    # @!attribute [rw] visibility_config
    #   Defines and enables Amazon CloudWatch metrics and web request sample
    #   collection.
    #   @return [Types::VisibilityConfig]
    #
    # @!attribute [rw] tags
    #   An array of key:value pairs to associate with the resource.
    #   @return [Array<Types::Tag>]
    #
    # @!attribute [rw] custom_response_bodies
    #   A map of custom response keys and content bodies. When you create a
    #   rule with a block action, you can send a custom response to the web
    #   request. You define these for the web ACL, and then use them in the
    #   rules and default actions that you define in the web ACL.
    #
    #   For information about customizing web requests and responses, see
    #   [Customizing web requests and responses in WAF][1] in the *WAF
    #   Developer Guide*.
    #
    #   For information about the limits on count and size for custom
    #   request and response settings, see [WAF quotas][2] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html
    #   [2]: https://docs.aws.amazon.com/waf/latest/developerguide/limits.html
    #   @return [Hash<String,Types::CustomResponseBody>]
    #
    # @!attribute [rw] captcha_config
    #   Specifies how WAF should handle `CAPTCHA` evaluations for rules that
    #   don't have their own `CaptchaConfig` settings. If you don't
    #   specify this, WAF uses its default settings for `CaptchaConfig`.
    #   @return [Types::CaptchaConfig]
    #
    # @!attribute [rw] challenge_config
    #   Specifies how WAF should handle challenge evaluations for rules that
    #   don't have their own `ChallengeConfig` settings. If you don't
    #   specify this, WAF uses its default settings for `ChallengeConfig`.
    #   @return [Types::ChallengeConfig]
    #
    # @!attribute [rw] token_domains
    #   Specifies the domains that WAF should accept in a web request token.
    #   This enables the use of tokens across multiple protected websites.
    #   When WAF provides a token, it uses the domain of the Amazon Web
    #   Services resource that the web ACL is protecting. If you don't
    #   specify a list of token domains, WAF accepts tokens only for the
    #   domain of the protected resource. With a token domain list, WAF
    #   accepts the resource's host domain plus all domains in the token
    #   domain list, including their prefixed subdomains.
    #
    #   Example JSON: `"TokenDomains": { "mywebsite.com",
    #   "myotherwebsite.com" }`
    #
    #   Public suffixes aren't allowed. For example, you can't use
    #   `gov.au` or `co.uk` as token domains.
    #   @return [Array<String>]
    #
    # @!attribute [rw] association_config
    #   Specifies custom configurations for the associations between the web
    #   ACL and protected resources.
    #
    #   Use this to customize the maximum size of the request body that your
    #   protected resources forward to WAF for inspection. You can customize
    #   this setting for CloudFront, API Gateway, Amazon Cognito, App
    #   Runner, or Verified Access resources. The default setting is 16 KB
    #   (16,384 bytes).
    #
    #   <note markdown="1"> You are charged additional fees when your protected resources
    #   forward body sizes that are larger than the default. For more
    #   information, see [WAF Pricing][1].
    #
    #    </note>
    #
    #   For Application Load Balancer and AppSync, the limit is fixed at 8
    #   KB (8,192 bytes).
    #
    #
    #
    #   [1]: http://aws.amazon.com/waf/pricing/
    #   @return [Types::AssociationConfig]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CreateWebACLRequest AWS API Documentation
    #
    class CreateWebACLRequest < Struct.new(
      :name,
      :scope,
      :default_action,
      :description,
      :rules,
      :visibility_config,
      :tags,
      :custom_response_bodies,
      :captcha_config,
      :challenge_config,
      :token_domains,
      :association_config)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] summary
    #   High-level information about a WebACL, returned by operations like
    #   create and list. This provides information like the ID, that you can
    #   use to retrieve and manage a `WebACL`, and the ARN, that you provide
    #   to operations like AssociateWebACL.
    #   @return [Types::WebACLSummary]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CreateWebACLResponse AWS API Documentation
    #
    class CreateWebACLResponse < Struct.new(
      :summary)
      SENSITIVE = []
      include Aws::Structure
    end

    # A custom header for custom request and response handling. This is used
    # in CustomResponse and CustomRequestHandling.
    #
    # @!attribute [rw] name
    #   The name of the custom header.
    #
    #   For custom request header insertion, when WAF inserts the header
    #   into the request, it prefixes this name `x-amzn-waf-`, to avoid
    #   confusion with the headers that are already in the request. For
    #   example, for the header name `sample`, WAF inserts the header
    #   `x-amzn-waf-sample`.
    #   @return [String]
    #
    # @!attribute [rw] value
    #   The value of the custom header.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CustomHTTPHeader AWS API Documentation
    #
    class CustomHTTPHeader < Struct.new(
      :name,
      :value)
      SENSITIVE = []
      include Aws::Structure
    end

    # Custom request handling behavior that inserts custom headers into a
    # web request. You can add custom request handling for WAF to use when
    # the rule action doesn't block the request. For example,
    # `CaptchaAction` for requests with valid t okens, and `AllowAction`.
    #
    # For information about customizing web requests and responses, see
    # [Customizing web requests and responses in WAF][1] in the *WAF
    # Developer Guide*.
    #
    #
    #
    # [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html
    #
    # @!attribute [rw] insert_headers
    #   The HTTP headers to insert into the request. Duplicate header names
    #   are not allowed.
    #
    #   For information about the limits on count and size for custom
    #   request and response settings, see [WAF quotas][1] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/limits.html
    #   @return [Array<Types::CustomHTTPHeader>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CustomRequestHandling AWS API Documentation
    #
    class CustomRequestHandling < Struct.new(
      :insert_headers)
      SENSITIVE = []
      include Aws::Structure
    end

    # A custom response to send to the client. You can define a custom
    # response for rule actions and default web ACL actions that are set to
    # BlockAction.
    #
    # For information about customizing web requests and responses, see
    # [Customizing web requests and responses in WAF][1] in the *WAF
    # Developer Guide*.
    #
    #
    #
    # [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html
    #
    # @!attribute [rw] response_code
    #   The HTTP status code to return to the client.
    #
    #   For a list of status codes that you can use in your custom
    #   responses, see [Supported status codes for custom response][1] in
    #   the *WAF Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/customizing-the-response-status-codes.html
    #   @return [Integer]
    #
    # @!attribute [rw] custom_response_body_key
    #   References the response body that you want WAF to return to the web
    #   request client. You can define a custom response for a rule action
    #   or a default web ACL action that is set to block. To do this, you
    #   first define the response body key and value in the
    #   `CustomResponseBodies` setting for the WebACL or RuleGroup where you
    #   want to use it. Then, in the rule action or web ACL default action
    #   `BlockAction` setting, you reference the response body using this
    #   key.
    #   @return [String]
    #
    # @!attribute [rw] response_headers
    #   The HTTP headers to use in the response. You can specify any header
    #   name except for `content-type`. Duplicate header names are not
    #   allowed.
    #
    #   For information about the limits on count and size for custom
    #   request and response settings, see [WAF quotas][1] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/limits.html
    #   @return [Array<Types::CustomHTTPHeader>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CustomResponse AWS API Documentation
    #
    class CustomResponse < Struct.new(
      :response_code,
      :custom_response_body_key,
      :response_headers)
      SENSITIVE = []
      include Aws::Structure
    end

    # The response body to use in a custom response to a web request. This
    # is referenced by key from CustomResponse `CustomResponseBodyKey`.
    #
    # @!attribute [rw] content_type
    #   The type of content in the payload that you are defining in the
    #   `Content` string.
    #   @return [String]
    #
    # @!attribute [rw] content
    #   The payload of the custom response.
    #
    #   You can use JSON escape strings in JSON content. To do this, you
    #   must specify JSON content in the `ContentType` setting.
    #
    #   For information about the limits on count and size for custom
    #   request and response settings, see [WAF quotas][1] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/limits.html
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/CustomResponseBody AWS API Documentation
    #
    class CustomResponseBody < Struct.new(
      :content_type,
      :content)
      SENSITIVE = []
      include Aws::Structure
    end

    # In a WebACL, this is the action that you want WAF to perform when a
    # web request doesn't match any of the rules in the `WebACL`. The
    # default action must be a terminating action.
    #
    # @!attribute [rw] block
    #   Specifies that WAF should block requests by default.
    #   @return [Types::BlockAction]
    #
    # @!attribute [rw] allow
    #   Specifies that WAF should allow requests by default.
    #   @return [Types::AllowAction]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DefaultAction AWS API Documentation
    #
    class DefaultAction < Struct.new(
      :block,
      :allow)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] api_key
    #   The encrypted API key that you want to delete.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteAPIKeyRequest AWS API Documentation
    #
    class DeleteAPIKeyRequest < Struct.new(
      :scope,
      :api_key)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteAPIKeyResponse AWS API Documentation
    #
    class DeleteAPIKeyResponse < Aws::EmptyStructure; end

    # @!attribute [rw] web_acl_arn
    #   The Amazon Resource Name (ARN) of the web ACL.
    #   @return [String]
    #
    # @!attribute [rw] web_acl_lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteFirewallManagerRuleGroupsRequest AWS API Documentation
    #
    class DeleteFirewallManagerRuleGroupsRequest < Struct.new(
      :web_acl_arn,
      :web_acl_lock_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_web_acl_lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteFirewallManagerRuleGroupsResponse AWS API Documentation
    #
    class DeleteFirewallManagerRuleGroupsResponse < Struct.new(
      :next_web_acl_lock_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] name
    #   The name of the IP set. You cannot change the name of an `IPSet`
    #   after you create it.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the set. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteIPSetRequest AWS API Documentation
    #
    class DeleteIPSetRequest < Struct.new(
      :name,
      :scope,
      :id,
      :lock_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteIPSetResponse AWS API Documentation
    #
    class DeleteIPSetResponse < Aws::EmptyStructure; end

    # @!attribute [rw] resource_arn
    #   The Amazon Resource Name (ARN) of the web ACL from which you want to
    #   delete the LoggingConfiguration.
    #   @return [String]
    #
    # @!attribute [rw] log_type
    #   Used to distinguish between various logging options. Currently,
    #   there is one option.
    #
    #   Default: `WAF_LOGS`
    #   @return [String]
    #
    # @!attribute [rw] log_scope
    #   The owner of the logging configuration, which must be set to
    #   `CUSTOMER` for the configurations that you manage.
    #
    #   The log scope `SECURITY_LAKE` indicates a configuration that is
    #   managed through Amazon Security Lake. You can use Security Lake to
    #   collect log and event data from various sources for normalization,
    #   analysis, and management. For information, see [Collecting data from
    #   Amazon Web Services services][1] in the *Amazon Security Lake user
    #   guide*.
    #
    #   Default: `CUSTOMER`
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/security-lake/latest/userguide/internal-sources.html
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteLoggingConfigurationRequest AWS API Documentation
    #
    class DeleteLoggingConfigurationRequest < Struct.new(
      :resource_arn,
      :log_type,
      :log_scope)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteLoggingConfigurationResponse AWS API Documentation
    #
    class DeleteLoggingConfigurationResponse < Aws::EmptyStructure; end

    # @!attribute [rw] resource_arn
    #   The Amazon Resource Name (ARN) of the rule group from which you want
    #   to delete the policy.
    #
    #   You must be the owner of the rule group to perform this operation.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeletePermissionPolicyRequest AWS API Documentation
    #
    class DeletePermissionPolicyRequest < Struct.new(
      :resource_arn)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeletePermissionPolicyResponse AWS API Documentation
    #
    class DeletePermissionPolicyResponse < Aws::EmptyStructure; end

    # @!attribute [rw] name
    #   The name of the set. You cannot change the name after you create the
    #   set.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the set. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteRegexPatternSetRequest AWS API Documentation
    #
    class DeleteRegexPatternSetRequest < Struct.new(
      :name,
      :scope,
      :id,
      :lock_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteRegexPatternSetResponse AWS API Documentation
    #
    class DeleteRegexPatternSetResponse < Aws::EmptyStructure; end

    # @!attribute [rw] name
    #   The name of the rule group. You cannot change the name of a rule
    #   group after you create it.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the rule group. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteRuleGroupRequest AWS API Documentation
    #
    class DeleteRuleGroupRequest < Struct.new(
      :name,
      :scope,
      :id,
      :lock_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteRuleGroupResponse AWS API Documentation
    #
    class DeleteRuleGroupResponse < Aws::EmptyStructure; end

    # @!attribute [rw] name
    #   The name of the web ACL. You cannot change the name of a web ACL
    #   after you create it.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   The unique identifier for the web ACL. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteWebACLRequest AWS API Documentation
    #
    class DeleteWebACLRequest < Struct.new(
      :name,
      :scope,
      :id,
      :lock_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DeleteWebACLResponse AWS API Documentation
    #
    class DeleteWebACLResponse < Aws::EmptyStructure; end

    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DescribeAllManagedProductsRequest AWS API Documentation
    #
    class DescribeAllManagedProductsRequest < Struct.new(
      :scope)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] managed_products
    #   High-level information for the Amazon Web Services Managed Rules
    #   rule groups and Amazon Web Services Marketplace managed rule groups.
    #   @return [Array<Types::ManagedProductDescriptor>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DescribeAllManagedProductsResponse AWS API Documentation
    #
    class DescribeAllManagedProductsResponse < Struct.new(
      :managed_products)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] vendor_name
    #   The name of the managed rule group vendor. You use this, along with
    #   the rule group name, to identify a rule group.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DescribeManagedProductsByVendorRequest AWS API Documentation
    #
    class DescribeManagedProductsByVendorRequest < Struct.new(
      :vendor_name,
      :scope)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] managed_products
    #   High-level information for the managed rule groups owned by the
    #   specified vendor.
    #   @return [Array<Types::ManagedProductDescriptor>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DescribeManagedProductsByVendorResponse AWS API Documentation
    #
    class DescribeManagedProductsByVendorResponse < Struct.new(
      :managed_products)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] vendor_name
    #   The name of the managed rule group vendor. You use this, along with
    #   the rule group name, to identify a rule group.
    #   @return [String]
    #
    # @!attribute [rw] name
    #   The name of the managed rule group. You use this, along with the
    #   vendor name, to identify the rule group.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] version_name
    #   The version of the rule group. You can only use a version that is
    #   not scheduled for expiration. If you don't provide this, WAF uses
    #   the vendor's default version.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DescribeManagedRuleGroupRequest AWS API Documentation
    #
    class DescribeManagedRuleGroupRequest < Struct.new(
      :vendor_name,
      :name,
      :scope,
      :version_name)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] version_name
    #   The managed rule group's version.
    #   @return [String]
    #
    # @!attribute [rw] sns_topic_arn
    #   The Amazon resource name (ARN) of the Amazon Simple Notification
    #   Service SNS topic that's used to provide notification of changes to
    #   the managed rule group. You can subscribe to the SNS topic to
    #   receive notifications when the managed rule group is modified, such
    #   as for new versions and for version expiration. For more
    #   information, see the [Amazon Simple Notification Service Developer
    #   Guide][1].
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/sns/latest/dg/welcome.html
    #   @return [String]
    #
    # @!attribute [rw] capacity
    #   The web ACL capacity units (WCUs) required for this rule group.
    #
    #   WAF uses WCUs to calculate and control the operating resources that
    #   are used to run your rules, rule groups, and web ACLs. WAF
    #   calculates capacity differently for each rule type, to reflect the
    #   relative cost of each rule. Simple rules that cost little to run use
    #   fewer WCUs than more complex rules that use more processing power.
    #   Rule group capacity is fixed at creation, which helps users plan
    #   their web ACL WCU usage when they use a rule group. For more
    #   information, see [WAF web ACL capacity units (WCU)][1] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/aws-waf-capacity-units.html
    #   @return [Integer]
    #
    # @!attribute [rw] rules
    #   @return [Array<Types::RuleSummary>]
    #
    # @!attribute [rw] label_namespace
    #   The label namespace prefix for this rule group. All labels added by
    #   rules in this rule group have this prefix.
    #
    #   * The syntax for the label namespace prefix for a managed rule group
    #     is the following:
    #
    #     `awswaf:managed:<vendor>:<rule group name>`:
    #
    #   * When a rule with a label matches a web request, WAF adds the fully
    #     qualified label to the request. A fully qualified label is made up
    #     of the label namespace from the rule group or web ACL where the
    #     rule is defined and the label from the rule, separated by a colon:
    #
    #     `<label namespace>:<label from rule>`
    #   @return [String]
    #
    # @!attribute [rw] available_labels
    #   The labels that one or more rules in this rule group add to matching
    #   web requests. These labels are defined in the `RuleLabels` for a
    #   Rule.
    #   @return [Array<Types::LabelSummary>]
    #
    # @!attribute [rw] consumed_labels
    #   The labels that one or more rules in this rule group match against
    #   in label match statements. These labels are defined in a
    #   `LabelMatchStatement` specification, in the Statement definition of
    #   a rule.
    #   @return [Array<Types::LabelSummary>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DescribeManagedRuleGroupResponse AWS API Documentation
    #
    class DescribeManagedRuleGroupResponse < Struct.new(
      :version_name,
      :sns_topic_arn,
      :capacity,
      :rules,
      :label_namespace,
      :available_labels,
      :consumed_labels)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] resource_arn
    #   The Amazon Resource Name (ARN) of the resource to disassociate from
    #   the web ACL.
    #
    #   The ARN must be in one of the following formats:
    #
    #   * For an Application Load Balancer:
    #     `arn:partition:elasticloadbalancing:region:account-id:loadbalancer/app/load-balancer-name/load-balancer-id
    #     `
    #
    #   * For an Amazon API Gateway REST API:
    #     `arn:partition:apigateway:region::/restapis/api-id/stages/stage-name
    #     `
    #
    #   * For an AppSync GraphQL API:
    #     `arn:partition:appsync:region:account-id:apis/GraphQLApiId `
    #
    #   * For an Amazon Cognito user pool:
    #     `arn:partition:cognito-idp:region:account-id:userpool/user-pool-id
    #     `
    #
    #   * For an App Runner service:
    #     `arn:partition:apprunner:region:account-id:service/apprunner-service-name/apprunner-service-id
    #     `
    #
    #   * For an Amazon Web Services Verified Access instance:
    #     `arn:partition:ec2:region:account-id:verified-access-instance/instance-id
    #     `
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DisassociateWebACLRequest AWS API Documentation
    #
    class DisassociateWebACLRequest < Struct.new(
      :resource_arn)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/DisassociateWebACLResponse AWS API Documentation
    #
    class DisassociateWebACLResponse < Aws::EmptyStructure; end

    # The name of the field in the request payload that contains your
    # customer's email.
    #
    # This data type is used in the `RequestInspectionACFP` data type.
    #
    # @!attribute [rw] identifier
    #   The name of the email field.
    #
    #   How you specify this depends on the request inspection payload type.
    #
    #   * For JSON payloads, specify the field name in JSON pointer syntax.
    #     For information about the JSON Pointer syntax, see the Internet
    #     Engineering Task Force (IETF) documentation [JavaScript Object
    #     Notation (JSON) Pointer][1].
    #
    #     For example, for the JSON payload `{ "form": { "email":
    #     "THE_EMAIL" } }`, the email field specification is `/form/email`.
    #
    #   * For form encoded payload types, use the HTML form names.
    #
    #     For example, for an HTML form with the input element named
    #     `email1`, the email field specification is `email1`.
    #
    #
    #
    #   [1]: https://tools.ietf.org/html/rfc6901
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/EmailField AWS API Documentation
    #
    class EmailField < Struct.new(
      :identifier)
      SENSITIVE = []
      include Aws::Structure
    end

    # Specifies a single rule in a rule group whose action you want to
    # override to `Count`.
    #
    # <note markdown="1"> Instead of this option, use `RuleActionOverrides`. It accepts any
    # valid action setting, including `Count`.
    #
    #  </note>
    #
    # @!attribute [rw] name
    #   The name of the rule whose action you want to override to `Count`.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ExcludedRule AWS API Documentation
    #
    class ExcludedRule < Struct.new(
      :name)
      SENSITIVE = []
      include Aws::Structure
    end

    # Specifies a web request component to be used in a rule match statement
    # or in a logging configuration.
    #
    # * In a rule statement, this is the part of the web request that you
    #   want WAF to inspect. Include the single `FieldToMatch` type that you
    #   want to inspect, with additional specifications as needed, according
    #   to the type. You specify a single request component in
    #   `FieldToMatch` for each rule statement that requires it. To inspect
    #   more than one component of the web request, create a separate rule
    #   statement for each component.
    #
    #   Example JSON for a `QueryString` field to match:
    #
    #   ` "FieldToMatch": { "QueryString": {} }`
    #
    #   Example JSON for a `Method` field to match specification:
    #
    #   ` "FieldToMatch": { "Method": { "Name": "DELETE" } }`
    #
    # * In a logging configuration, this is used in the `RedactedFields`
    #   property to specify a field to redact from the logging records. For
    #   this use case, note the following:
    #
    #   * Even though all `FieldToMatch` settings are available, the only
    #     valid settings for field redaction are `UriPath`, `QueryString`,
    #     `SingleHeader`, and `Method`.
    #
    #   * In this documentation, the descriptions of the individual fields
    #     talk about specifying the web request component to inspect, but
    #     for field redaction, you are specifying the component type to
    #     redact from the logs.
    #
    #   * If you have request sampling enabled, the redacted fields
    #     configuration for logging has no impact on sampling. The only way
    #     to exclude fields from request sampling is by disabling sampling
    #     in the web ACL visibility configuration.
    #
    # @!attribute [rw] single_header
    #   Inspect a single header. Provide the name of the header to inspect,
    #   for example, `User-Agent` or `Referer`. This setting isn't case
    #   sensitive.
    #
    #   Example JSON: `"SingleHeader": { "Name": "haystack" }`
    #
    #   Alternately, you can filter and inspect all headers with the
    #   `Headers` `FieldToMatch` setting.
    #   @return [Types::SingleHeader]
    #
    # @!attribute [rw] single_query_argument
    #   Inspect a single query argument. Provide the name of the query
    #   argument to inspect, such as *UserName* or *SalesRegion*. The name
    #   can be up to 30 characters long and isn't case sensitive.
    #
    #   Example JSON: `"SingleQueryArgument": { "Name": "myArgument" }`
    #   @return [Types::SingleQueryArgument]
    #
    # @!attribute [rw] all_query_arguments
    #   Inspect all query arguments.
    #   @return [Types::AllQueryArguments]
    #
    # @!attribute [rw] uri_path
    #   Inspect the request URI path. This is the part of the web request
    #   that identifies a resource, for example, `/images/daily-ad.jpg`.
    #   @return [Types::UriPath]
    #
    # @!attribute [rw] query_string
    #   Inspect the query string. This is the part of a URL that appears
    #   after a `?` character, if any.
    #   @return [Types::QueryString]
    #
    # @!attribute [rw] body
    #   Inspect the request body as plain text. The request body immediately
    #   follows the request headers. This is the part of a request that
    #   contains any additional data that you want to send to your web
    #   server as the HTTP request body, such as data from a form.
    #
    #   WAF does not support inspecting the entire contents of the web
    #   request body if the body exceeds the limit for the resource type.
    #   When a web request body is larger than the limit, the underlying
    #   host service only forwards the contents that are within the limit to
    #   WAF for inspection.
    #
    #   * For Application Load Balancer and AppSync, the limit is fixed at 8
    #     KB (8,192 bytes).
    #
    #   * For CloudFront, API Gateway, Amazon Cognito, App Runner, and
    #     Verified Access, the default limit is 16 KB (16,384 bytes), and
    #     you can increase the limit for each resource type in the web ACL
    #     `AssociationConfig`, for additional processing fees.
    #
    #   For information about how to handle oversized request bodies, see
    #   the `Body` object configuration.
    #   @return [Types::Body]
    #
    # @!attribute [rw] method
    #   Inspect the HTTP method. The method indicates the type of operation
    #   that the request is asking the origin to perform.
    #   @return [Types::Method]
    #
    # @!attribute [rw] json_body
    #   Inspect the request body as JSON. The request body immediately
    #   follows the request headers. This is the part of a request that
    #   contains any additional data that you want to send to your web
    #   server as the HTTP request body, such as data from a form.
    #
    #   WAF does not support inspecting the entire contents of the web
    #   request body if the body exceeds the limit for the resource type.
    #   When a web request body is larger than the limit, the underlying
    #   host service only forwards the contents that are within the limit to
    #   WAF for inspection.
    #
    #   * For Application Load Balancer and AppSync, the limit is fixed at 8
    #     KB (8,192 bytes).
    #
    #   * For CloudFront, API Gateway, Amazon Cognito, App Runner, and
    #     Verified Access, the default limit is 16 KB (16,384 bytes), and
    #     you can increase the limit for each resource type in the web ACL
    #     `AssociationConfig`, for additional processing fees.
    #
    #   For information about how to handle oversized request bodies, see
    #   the `JsonBody` object configuration.
    #   @return [Types::JsonBody]
    #
    # @!attribute [rw] headers
    #   Inspect the request headers. You must configure scope and pattern
    #   matching filters in the `Headers` object, to define the set of
    #   headers to and the parts of the headers that WAF inspects.
    #
    #   Only the first 8 KB (8192 bytes) of a request's headers and only
    #   the first 200 headers are forwarded to WAF for inspection by the
    #   underlying host service. You must configure how to handle any
    #   oversize header content in the `Headers` object. WAF applies the
    #   pattern matching filters to the headers that it receives from the
    #   underlying host service.
    #   @return [Types::Headers]
    #
    # @!attribute [rw] cookies
    #   Inspect the request cookies. You must configure scope and pattern
    #   matching filters in the `Cookies` object, to define the set of
    #   cookies and the parts of the cookies that WAF inspects.
    #
    #   Only the first 8 KB (8192 bytes) of a request's cookies and only
    #   the first 200 cookies are forwarded to WAF for inspection by the
    #   underlying host service. You must configure how to handle any
    #   oversize cookie content in the `Cookies` object. WAF applies the
    #   pattern matching filters to the cookies that it receives from the
    #   underlying host service.
    #   @return [Types::Cookies]
    #
    # @!attribute [rw] header_order
    #   Inspect a string containing the list of the request's header names,
    #   ordered as they appear in the web request that WAF receives for
    #   inspection. WAF generates the string and then uses that as the field
    #   to match component in its inspection. WAF separates the header names
    #   in the string using colons and no added spaces, for example
    #   `host:user-agent:accept:authorization:referer`.
    #   @return [Types::HeaderOrder]
    #
    # @!attribute [rw] ja3_fingerprint
    #   Available for use with Amazon CloudFront distributions and
    #   Application Load Balancers. Match against the request's JA3
    #   fingerprint. The JA3 fingerprint is a 32-character hash derived from
    #   the TLS Client Hello of an incoming request. This fingerprint serves
    #   as a unique identifier for the client's TLS configuration. WAF
    #   calculates and logs this fingerprint for each request that has
    #   enough TLS Client Hello information for the calculation. Almost all
    #   web requests include this information.
    #
    #   <note markdown="1"> You can use this choice only with a string match
    #   `ByteMatchStatement` with the `PositionalConstraint` set to
    #   `EXACTLY`.
    #
    #    </note>
    #
    #   You can obtain the JA3 fingerprint for client requests from the web
    #   ACL logs. If WAF is able to calculate the fingerprint, it includes
    #   it in the logs. For information about the logging fields, see [Log
    #   fields][1] in the *WAF Developer Guide*.
    #
    #   Provide the JA3 fingerprint string from the logs in your string
    #   match statement specification, to match with any future requests
    #   that have the same TLS configuration.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/logging-fields.html
    #   @return [Types::JA3Fingerprint]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/FieldToMatch AWS API Documentation
    #
    class FieldToMatch < Struct.new(
      :single_header,
      :single_query_argument,
      :all_query_arguments,
      :uri_path,
      :query_string,
      :body,
      :method,
      :json_body,
      :headers,
      :cookies,
      :header_order,
      :ja3_fingerprint)
      SENSITIVE = []
      include Aws::Structure
    end

    # A single logging filter, used in LoggingFilter.
    #
    # @!attribute [rw] behavior
    #   How to handle logs that satisfy the filter's conditions and
    #   requirement.
    #   @return [String]
    #
    # @!attribute [rw] requirement
    #   Logic to apply to the filtering conditions. You can specify that, in
    #   order to satisfy the filter, a log must match all conditions or must
    #   match at least one condition.
    #   @return [String]
    #
    # @!attribute [rw] conditions
    #   Match conditions for the filter.
    #   @return [Array<Types::Condition>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/Filter AWS API Documentation
    #
    class Filter < Struct.new(
      :behavior,
      :requirement,
      :conditions)
      SENSITIVE = []
      include Aws::Structure
    end

    # A rule group that's defined for an Firewall Manager WAF policy.
    #
    # @!attribute [rw] name
    #   The name of the rule group. You cannot change the name of a rule
    #   group after you create it.
    #   @return [String]
    #
    # @!attribute [rw] priority
    #   If you define more than one rule group in the first or last Firewall
    #   Manager rule groups, WAF evaluates each request against the rule
    #   groups in order, starting from the lowest priority setting. The
    #   priorities don't need to be consecutive, but they must all be
    #   different.
    #   @return [Integer]
    #
    # @!attribute [rw] firewall_manager_statement
    #   The processing guidance for an Firewall Manager rule. This is like a
    #   regular rule Statement, but it can only contain a rule group
    #   reference.
    #   @return [Types::FirewallManagerStatement]
    #
    # @!attribute [rw] override_action
    #   The action to use in the place of the action that results from the
    #   rule group evaluation. Set the override action to none to leave the
    #   result of the rule group alone. Set it to count to override the
    #   result to count only.
    #
    #   You can only use this for rule statements that reference a rule
    #   group, like `RuleGroupReferenceStatement` and
    #   `ManagedRuleGroupStatement`.
    #
    #   <note markdown="1"> This option is usually set to none. It does not affect how the rules
    #   in the rule group are evaluated. If you want the rules in the rule
    #   group to only count matches, do not use this and instead use the
    #   rule action override option, with `Count` action, in your rule group
    #   reference statement settings.
    #
    #    </note>
    #   @return [Types::OverrideAction]
    #
    # @!attribute [rw] visibility_config
    #   Defines and enables Amazon CloudWatch metrics and web request sample
    #   collection.
    #   @return [Types::VisibilityConfig]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/FirewallManagerRuleGroup AWS API Documentation
    #
    class FirewallManagerRuleGroup < Struct.new(
      :name,
      :priority,
      :firewall_manager_statement,
      :override_action,
      :visibility_config)
      SENSITIVE = []
      include Aws::Structure
    end

    # The processing guidance for an Firewall Manager rule. This is like a
    # regular rule Statement, but it can only contain a single rule group
    # reference.
    #
    # @!attribute [rw] managed_rule_group_statement
    #   A statement used by Firewall Manager to run the rules that are
    #   defined in a managed rule group. This is managed by Firewall Manager
    #   for an Firewall Manager WAF policy.
    #   @return [Types::ManagedRuleGroupStatement]
    #
    # @!attribute [rw] rule_group_reference_statement
    #   A statement used by Firewall Manager to run the rules that are
    #   defined in a rule group. This is managed by Firewall Manager for an
    #   Firewall Manager WAF policy.
    #   @return [Types::RuleGroupReferenceStatement]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/FirewallManagerStatement AWS API Documentation
    #
    class FirewallManagerStatement < Struct.new(
      :managed_rule_group_statement,
      :rule_group_reference_statement)
      SENSITIVE = []
      include Aws::Structure
    end

    # 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.
    #
    # <note markdown="1"> If the specified header isn't present in the request, WAF doesn't
    # apply the rule to the web request at all.
    #
    #  </note>
    #
    # This configuration is used for GeoMatchStatement and
    # RateBasedStatement. For IPSetReferenceStatement, use
    # IPSetForwardedIPConfig instead.
    #
    # WAF only evaluates the first IP address found in the specified HTTP
    # header.
    #
    # @!attribute [rw] header_name
    #   The name of the HTTP header to use for the IP address. For example,
    #   to use the X-Forwarded-For (XFF) header, set this to
    #   `X-Forwarded-For`.
    #
    #   <note markdown="1"> If the specified header isn't present in the request, WAF doesn't
    #   apply the rule to the web request at all.
    #
    #    </note>
    #   @return [String]
    #
    # @!attribute [rw] fallback_behavior
    #   The match status to assign to the web request if the request
    #   doesn't have a valid IP address in the specified position.
    #
    #   <note markdown="1"> If the specified header isn't present in the request, WAF doesn't
    #   apply the rule to the web request at all.
    #
    #    </note>
    #
    #   You can specify the following fallback behaviors:
    #
    #   * `MATCH` - Treat the web request as matching the rule statement.
    #     WAF applies the rule action to the request.
    #
    #   * `NO_MATCH` - Treat the web request as not matching the rule
    #     statement.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ForwardedIPConfig AWS API Documentation
    #
    class ForwardedIPConfig < Struct.new(
      :header_name,
      :fallback_behavior)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] platform
    #   The device platform.
    #   @return [String]
    #
    # @!attribute [rw] release_version
    #   The release version. For the latest available version, specify
    #   `LATEST`.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GenerateMobileSdkReleaseUrlRequest AWS API Documentation
    #
    class GenerateMobileSdkReleaseUrlRequest < Struct.new(
      :platform,
      :release_version)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] url
    #   The presigned download URL for the specified SDK release.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GenerateMobileSdkReleaseUrlResponse AWS API Documentation
    #
    class GenerateMobileSdkReleaseUrlResponse < Struct.new(
      :url)
      SENSITIVE = []
      include Aws::Structure
    end

    # 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 `CountryCodes` array.
    #
    # * 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.
    #
    # WAF labels requests using the alpha-2 country and region codes from
    # the International Organization for Standardization (ISO) 3166
    # standard. 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][1] in
    # the [WAF Developer Guide][2].
    #
    #
    #
    # [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-rule-statement-type-geo-match.html
    # [2]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html
    #
    # @!attribute [rw] country_codes
    #   An array of two-character country codes that you want to match
    #   against, for example, `[ "US", "CN" ]`, from the alpha-2 country ISO
    #   codes of the ISO 3166 international standard.
    #
    #   When you use a geo match statement just for the region and country
    #   labels that it adds to requests, you still have to supply a country
    #   code for the rule to evaluate. In this case, you configure the rule
    #   to only count matching requests, but it will still generate logging
    #   and count metrics for any matches. You can reduce the logging and
    #   metrics that the rule produces by specifying a country that's
    #   unlikely to be a source of traffic to your site.
    #   @return [Array<String>]
    #
    # @!attribute [rw] forwarded_ip_config
    #   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.
    #
    #   <note markdown="1"> If the specified header isn't present in the request, WAF doesn't
    #   apply the rule to the web request at all.
    #
    #    </note>
    #   @return [Types::ForwardedIPConfig]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GeoMatchStatement AWS API Documentation
    #
    class GeoMatchStatement < Struct.new(
      :country_codes,
      :forwarded_ip_config)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] api_key
    #   The encrypted API key.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetDecryptedAPIKeyRequest AWS API Documentation
    #
    class GetDecryptedAPIKeyRequest < Struct.new(
      :scope,
      :api_key)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] token_domains
    #   The token domains that are defined in this API key.
    #   @return [Array<String>]
    #
    # @!attribute [rw] creation_timestamp
    #   The date and time that the key was created.
    #   @return [Time]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetDecryptedAPIKeyResponse AWS API Documentation
    #
    class GetDecryptedAPIKeyResponse < Struct.new(
      :token_domains,
      :creation_timestamp)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] name
    #   The name of the IP set. You cannot change the name of an `IPSet`
    #   after you create it.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the set. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetIPSetRequest AWS API Documentation
    #
    class GetIPSetRequest < Struct.new(
      :name,
      :scope,
      :id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] ip_set
    #   @return [Types::IPSet]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetIPSetResponse AWS API Documentation
    #
    class GetIPSetResponse < Struct.new(
      :ip_set,
      :lock_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] resource_arn
    #   The Amazon Resource Name (ARN) of the web ACL for which you want to
    #   get the LoggingConfiguration.
    #   @return [String]
    #
    # @!attribute [rw] log_type
    #   Used to distinguish between various logging options. Currently,
    #   there is one option.
    #
    #   Default: `WAF_LOGS`
    #   @return [String]
    #
    # @!attribute [rw] log_scope
    #   The owner of the logging configuration, which must be set to
    #   `CUSTOMER` for the configurations that you manage.
    #
    #   The log scope `SECURITY_LAKE` indicates a configuration that is
    #   managed through Amazon Security Lake. You can use Security Lake to
    #   collect log and event data from various sources for normalization,
    #   analysis, and management. For information, see [Collecting data from
    #   Amazon Web Services services][1] in the *Amazon Security Lake user
    #   guide*.
    #
    #   Default: `CUSTOMER`
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/security-lake/latest/userguide/internal-sources.html
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetLoggingConfigurationRequest AWS API Documentation
    #
    class GetLoggingConfigurationRequest < Struct.new(
      :resource_arn,
      :log_type,
      :log_scope)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] logging_configuration
    #   The LoggingConfiguration for the specified web ACL.
    #   @return [Types::LoggingConfiguration]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetLoggingConfigurationResponse AWS API Documentation
    #
    class GetLoggingConfigurationResponse < Struct.new(
      :logging_configuration)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] name
    #   The name of the managed rule set. You use this, along with the rule
    #   set ID, to identify the rule set.
    #
    #   This name is assigned to the corresponding managed rule group, which
    #   your customers can access and use.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the managed rule set. The ID is returned in
    #   the responses to commands like `list`. You provide it to operations
    #   like `get` and `update`.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetManagedRuleSetRequest AWS API Documentation
    #
    class GetManagedRuleSetRequest < Struct.new(
      :name,
      :scope,
      :id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] managed_rule_set
    #   The managed rule set that you requested.
    #   @return [Types::ManagedRuleSet]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetManagedRuleSetResponse AWS API Documentation
    #
    class GetManagedRuleSetResponse < Struct.new(
      :managed_rule_set,
      :lock_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] platform
    #   The device platform.
    #   @return [String]
    #
    # @!attribute [rw] release_version
    #   The release version. For the latest available version, specify
    #   `LATEST`.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetMobileSdkReleaseRequest AWS API Documentation
    #
    class GetMobileSdkReleaseRequest < Struct.new(
      :platform,
      :release_version)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] mobile_sdk_release
    #   Information for a specified SDK release, including release notes and
    #   tags.
    #   @return [Types::MobileSdkRelease]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetMobileSdkReleaseResponse AWS API Documentation
    #
    class GetMobileSdkReleaseResponse < Struct.new(
      :mobile_sdk_release)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] resource_arn
    #   The Amazon Resource Name (ARN) of the rule group for which you want
    #   to get the policy.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetPermissionPolicyRequest AWS API Documentation
    #
    class GetPermissionPolicyRequest < Struct.new(
      :resource_arn)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] policy
    #   The IAM policy that is attached to the specified rule group.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetPermissionPolicyResponse AWS API Documentation
    #
    class GetPermissionPolicyResponse < Struct.new(
      :policy)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] web_acl_name
    #   The name of the web ACL. You cannot change the name of a web ACL
    #   after you create it.
    #   @return [String]
    #
    # @!attribute [rw] web_acl_id
    #   The unique identifier for the web ACL. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @!attribute [rw] rule_group_rule_name
    #   The name of the rule group reference statement in your web ACL. This
    #   is required only when you have the rate-based rule nested inside a
    #   rule group.
    #   @return [String]
    #
    # @!attribute [rw] rule_name
    #   The name of the rate-based rule to get the keys for. If you have the
    #   rule defined inside a rule group that you're using in your web ACL,
    #   also provide the name of the rule group reference statement in the
    #   request parameter `RuleGroupRuleName`.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetRateBasedStatementManagedKeysRequest AWS API Documentation
    #
    class GetRateBasedStatementManagedKeysRequest < Struct.new(
      :scope,
      :web_acl_name,
      :web_acl_id,
      :rule_group_rule_name,
      :rule_name)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] managed_keys_ipv4
    #   The keys that are of Internet Protocol version 4 (IPv4).
    #   @return [Types::RateBasedStatementManagedKeysIPSet]
    #
    # @!attribute [rw] managed_keys_ipv6
    #   The keys that are of Internet Protocol version 6 (IPv6).
    #   @return [Types::RateBasedStatementManagedKeysIPSet]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetRateBasedStatementManagedKeysResponse AWS API Documentation
    #
    class GetRateBasedStatementManagedKeysResponse < Struct.new(
      :managed_keys_ipv4,
      :managed_keys_ipv6)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] name
    #   The name of the set. You cannot change the name after you create the
    #   set.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the set. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetRegexPatternSetRequest AWS API Documentation
    #
    class GetRegexPatternSetRequest < Struct.new(
      :name,
      :scope,
      :id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] regex_pattern_set
    #   @return [Types::RegexPatternSet]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetRegexPatternSetResponse AWS API Documentation
    #
    class GetRegexPatternSetResponse < Struct.new(
      :regex_pattern_set,
      :lock_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] name
    #   The name of the rule group. You cannot change the name of a rule
    #   group after you create it.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the rule group. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the entity.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetRuleGroupRequest AWS API Documentation
    #
    class GetRuleGroupRequest < Struct.new(
      :name,
      :scope,
      :id,
      :arn)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] rule_group
    #   @return [Types::RuleGroup]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetRuleGroupResponse AWS API Documentation
    #
    class GetRuleGroupResponse < Struct.new(
      :rule_group,
      :lock_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] web_acl_arn
    #   The Amazon resource name (ARN) of the `WebACL` for which you want a
    #   sample of requests.
    #   @return [String]
    #
    # @!attribute [rw] rule_metric_name
    #   The metric name assigned to the `Rule` or `RuleGroup` dimension for
    #   which you want a sample of requests.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] time_window
    #   The start date and time and the end date and time of the range for
    #   which you want `GetSampledRequests` to return a sample of requests.
    #   You must specify the times in Coordinated Universal Time (UTC)
    #   format. UTC format includes the special designator, `Z`. For
    #   example, `"2016-09-27T14:50Z"`. You can specify any time range in
    #   the previous three hours. If you specify a start time that's
    #   earlier than three hours ago, WAF sets it to three hours ago.
    #   @return [Types::TimeWindow]
    #
    # @!attribute [rw] max_items
    #   The number of requests that you want WAF to return from among the
    #   first 5,000 requests that your Amazon Web Services resource received
    #   during the time range. If your resource received fewer requests than
    #   the value of `MaxItems`, `GetSampledRequests` returns information
    #   about all of them.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetSampledRequestsRequest AWS API Documentation
    #
    class GetSampledRequestsRequest < Struct.new(
      :web_acl_arn,
      :rule_metric_name,
      :scope,
      :time_window,
      :max_items)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] sampled_requests
    #   A complex type that contains detailed information about each of the
    #   requests in the sample.
    #   @return [Array<Types::SampledHTTPRequest>]
    #
    # @!attribute [rw] population_size
    #   The total number of requests from which `GetSampledRequests` got a
    #   sample of `MaxItems` requests. If `PopulationSize` is less than
    #   `MaxItems`, the sample includes every request that your Amazon Web
    #   Services resource received during the specified time range.
    #   @return [Integer]
    #
    # @!attribute [rw] time_window
    #   Usually, `TimeWindow` is the time range that you specified in the
    #   `GetSampledRequests` request. However, if your Amazon Web Services
    #   resource received more than 5,000 requests during the time range
    #   that you specified in the request, `GetSampledRequests` returns the
    #   time range for the first 5,000 requests. Times are in Coordinated
    #   Universal Time (UTC) format.
    #   @return [Types::TimeWindow]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetSampledRequestsResponse AWS API Documentation
    #
    class GetSampledRequestsResponse < Struct.new(
      :sampled_requests,
      :population_size,
      :time_window)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] resource_arn
    #   The Amazon Resource Name (ARN) of the resource whose web ACL you
    #   want to retrieve.
    #
    #   The ARN must be in one of the following formats:
    #
    #   * For an Application Load Balancer:
    #     `arn:partition:elasticloadbalancing:region:account-id:loadbalancer/app/load-balancer-name/load-balancer-id
    #     `
    #
    #   * For an Amazon API Gateway REST API:
    #     `arn:partition:apigateway:region::/restapis/api-id/stages/stage-name
    #     `
    #
    #   * For an AppSync GraphQL API:
    #     `arn:partition:appsync:region:account-id:apis/GraphQLApiId `
    #
    #   * For an Amazon Cognito user pool:
    #     `arn:partition:cognito-idp:region:account-id:userpool/user-pool-id
    #     `
    #
    #   * For an App Runner service:
    #     `arn:partition:apprunner:region:account-id:service/apprunner-service-name/apprunner-service-id
    #     `
    #
    #   * For an Amazon Web Services Verified Access instance:
    #     `arn:partition:ec2:region:account-id:verified-access-instance/instance-id
    #     `
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetWebACLForResourceRequest AWS API Documentation
    #
    class GetWebACLForResourceRequest < Struct.new(
      :resource_arn)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] web_acl
    #   The web ACL that is associated with the resource. If there is no
    #   associated resource, WAF returns a null web ACL.
    #   @return [Types::WebACL]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetWebACLForResourceResponse AWS API Documentation
    #
    class GetWebACLForResourceResponse < Struct.new(
      :web_acl)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] name
    #   The name of the web ACL. You cannot change the name of a web ACL
    #   after you create it.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   The unique identifier for the web ACL. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetWebACLRequest AWS API Documentation
    #
    class GetWebACLRequest < Struct.new(
      :name,
      :scope,
      :id)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] web_acl
    #   The web ACL specification. You can modify the settings in this web
    #   ACL and use it to update this web ACL or create a new one.
    #   @return [Types::WebACL]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @!attribute [rw] application_integration_url
    #   The URL to use in SDK integrations with Amazon Web Services managed
    #   rule groups. For example, you can use the integration SDKs with the
    #   account takeover prevention managed rule group
    #   `AWSManagedRulesATPRuleSet` and the account creation fraud
    #   prevention managed rule group `AWSManagedRulesACFPRuleSet`. This is
    #   only populated if you are using a rule group in your web ACL that
    #   integrates with your applications in this way. For more information,
    #   see [WAF client application integration][1] in the *WAF Developer
    #   Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-application-integration.html
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/GetWebACLResponse AWS API Documentation
    #
    class GetWebACLResponse < Struct.new(
      :web_acl,
      :lock_token,
      :application_integration_url)
      SENSITIVE = []
      include Aws::Structure
    end

    # Part of the response from GetSampledRequests. This is a complex type
    # that appears as `Headers` in the response syntax. `HTTPHeader`
    # contains the names and values of all of the headers that appear in one
    # of the web requests.
    #
    # @!attribute [rw] name
    #   The name of the HTTP header.
    #   @return [String]
    #
    # @!attribute [rw] value
    #   The value of the HTTP header.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/HTTPHeader AWS API Documentation
    #
    class HTTPHeader < Struct.new(
      :name,
      :value)
      SENSITIVE = []
      include Aws::Structure
    end

    # Part of the response from GetSampledRequests. This is a complex type
    # that appears as `Request` in the response syntax. `HTTPRequest`
    # contains information about one of the web requests.
    #
    # @!attribute [rw] client_ip
    #   The IP address that the request originated from. If the web ACL is
    #   associated with a CloudFront distribution, this is the value of one
    #   of the following fields in CloudFront access logs:
    #
    #   * `c-ip`, if the viewer did not use an HTTP proxy or a load balancer
    #     to send the request
    #
    #   * `x-forwarded-for`, if the viewer did use an HTTP proxy or a load
    #     balancer to send the request
    #   @return [String]
    #
    # @!attribute [rw] country
    #   The two-letter country code for the country that the request
    #   originated from. For a current list of country codes, see the
    #   Wikipedia entry [ISO 3166-1 alpha-2][1].
    #
    #
    #
    #   [1]: https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2
    #   @return [String]
    #
    # @!attribute [rw] uri
    #   The URI path of the request, which identifies the resource, for
    #   example, `/images/daily-ad.jpg`.
    #   @return [String]
    #
    # @!attribute [rw] method
    #   The HTTP method specified in the sampled web request.
    #   @return [String]
    #
    # @!attribute [rw] http_version
    #   The HTTP version specified in the sampled web request, for example,
    #   `HTTP/1.1`.
    #   @return [String]
    #
    # @!attribute [rw] headers
    #   A complex type that contains the name and value for each header in
    #   the sampled web request.
    #   @return [Array<Types::HTTPHeader>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/HTTPRequest AWS API Documentation
    #
    class HTTPRequest < Struct.new(
      :client_ip,
      :country,
      :uri,
      :method,
      :http_version,
      :headers)
      SENSITIVE = []
      include Aws::Structure
    end

    # The filter to use to identify the subset of headers to inspect in a
    # web request.
    #
    # You must specify exactly one setting: either `All`, `IncludedHeaders`,
    # or `ExcludedHeaders`.
    #
    # Example JSON: `"MatchPattern": { "ExcludedHeaders": [ "KeyToExclude1",
    # "KeyToExclude2" ] }`
    #
    # @!attribute [rw] all
    #   Inspect all headers.
    #   @return [Types::All]
    #
    # @!attribute [rw] included_headers
    #   Inspect only the headers that have a key that matches one of the
    #   strings specified here.
    #   @return [Array<String>]
    #
    # @!attribute [rw] excluded_headers
    #   Inspect only the headers whose keys don't match any of the strings
    #   specified here.
    #   @return [Array<String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/HeaderMatchPattern AWS API Documentation
    #
    class HeaderMatchPattern < Struct.new(
      :all,
      :included_headers,
      :excluded_headers)
      SENSITIVE = []
      include Aws::Structure
    end

    # Inspect a string containing the list of the request's header names,
    # ordered as they appear in the web request that WAF receives for
    # inspection. WAF generates the string and then uses that as the field
    # to match component in its inspection. WAF separates the header names
    # in the string using colons and no added spaces, for example
    # `host:user-agent:accept:authorization:referer`.
    #
    # @!attribute [rw] oversize_handling
    #   What WAF should do if the headers of the request are more numerous
    #   or larger than WAF can inspect. WAF does not support inspecting the
    #   entire contents of request headers when they exceed 8 KB (8192
    #   bytes) or 200 total headers. The underlying host service forwards a
    #   maximum of 200 headers and at most 8 KB of header contents to WAF.
    #
    #   The options for oversize handling are the following:
    #
    #   * `CONTINUE` - Inspect the available headers normally, according to
    #     the rule inspection criteria.
    #
    #   * `MATCH` - Treat the web request as matching the rule statement.
    #     WAF applies the rule action to the request.
    #
    #   * `NO_MATCH` - Treat the web request as not matching the rule
    #     statement.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/HeaderOrder AWS API Documentation
    #
    class HeaderOrder < Struct.new(
      :oversize_handling)
      SENSITIVE = []
      include Aws::Structure
    end

    # Inspect all headers in the web request. You can specify the parts of
    # the headers to inspect and you can narrow the set of headers to
    # inspect by including or excluding specific keys.
    #
    # This is used to indicate the web request component to inspect, in the
    # FieldToMatch specification.
    #
    # If you want to inspect just the value of a single header, use the
    # `SingleHeader` `FieldToMatch` setting instead.
    #
    # Example JSON: `"Headers": { "MatchPattern": { "All": {} },
    # "MatchScope": "KEY", "OversizeHandling": "MATCH" }`
    #
    # @!attribute [rw] match_pattern
    #   The filter to use to identify the subset of headers to inspect in a
    #   web request.
    #
    #   You must specify exactly one setting: either `All`,
    #   `IncludedHeaders`, or `ExcludedHeaders`.
    #
    #   Example JSON: `"MatchPattern": { "ExcludedHeaders": [
    #   "KeyToExclude1", "KeyToExclude2" ] }`
    #   @return [Types::HeaderMatchPattern]
    #
    # @!attribute [rw] match_scope
    #   The parts of the headers to match with the rule inspection criteria.
    #   If you specify `ALL`, WAF inspects both keys and values.
    #
    #   `All` does not require a match to be found in the keys and a match
    #   to be found in the values. It requires a match to be found in the
    #   keys or the values or both. To require a match in the keys and in
    #   the values, use a logical `AND` statement to combine two match
    #   rules, one that inspects the keys and another that inspects the
    #   values.
    #   @return [String]
    #
    # @!attribute [rw] oversize_handling
    #   What WAF should do if the headers of the request are more numerous
    #   or larger than WAF can inspect. WAF does not support inspecting the
    #   entire contents of request headers when they exceed 8 KB (8192
    #   bytes) or 200 total headers. The underlying host service forwards a
    #   maximum of 200 headers and at most 8 KB of header contents to WAF.
    #
    #   The options for oversize handling are the following:
    #
    #   * `CONTINUE` - Inspect the available headers normally, according to
    #     the rule inspection criteria.
    #
    #   * `MATCH` - Treat the web request as matching the rule statement.
    #     WAF applies the rule action to the request.
    #
    #   * `NO_MATCH` - Treat the web request as not matching the rule
    #     statement.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/Headers AWS API Documentation
    #
    class Headers < Struct.new(
      :match_pattern,
      :match_scope,
      :oversize_handling)
      SENSITIVE = []
      include Aws::Structure
    end

    # Contains zero or more IP addresses or blocks of IP addresses specified
    # in Classless Inter-Domain Routing (CIDR) notation. WAF supports all
    # IPv4 and IPv6 CIDR ranges except for /0. For information about CIDR
    # notation, see the Wikipedia entry [Classless Inter-Domain Routing][1].
    #
    # WAF assigns an ARN to each `IPSet` that you create. To use an IP set
    # in a rule, you provide the ARN to the Rule statement
    # IPSetReferenceStatement.
    #
    #
    #
    # [1]: https://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing
    #
    # @!attribute [rw] name
    #   The name of the IP set. You cannot change the name of an `IPSet`
    #   after you create it.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the set. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the entity.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   A description of the IP set that helps with identification.
    #   @return [String]
    #
    # @!attribute [rw] ip_address_version
    #   The version of the IP addresses, either `IPV4` or `IPV6`.
    #   @return [String]
    #
    # @!attribute [rw] addresses
    #   Contains an array of strings that specifies zero or more IP
    #   addresses or blocks of IP addresses that you want WAF to inspect for
    #   in incoming requests. All addresses must be specified using
    #   Classless Inter-Domain Routing (CIDR) notation. WAF supports all
    #   IPv4 and IPv6 CIDR ranges except for `/0`.
    #
    #   Example address strings:
    #
    #   * For requests that originated from the IP address 192.0.2.44,
    #     specify `192.0.2.44/32`.
    #
    #   * For requests that originated from IP addresses from 192.0.2.0 to
    #     192.0.2.255, specify `192.0.2.0/24`.
    #
    #   * For 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`.
    #
    #   * For 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`.
    #
    #   For more information about CIDR notation, see the Wikipedia entry
    #   [Classless Inter-Domain Routing][1].
    #
    #   Example JSON `Addresses` specifications:
    #
    #   * Empty array: `"Addresses": []`
    #
    #   * Array with one address: `"Addresses": ["192.0.2.44/32"]`
    #
    #   * Array with three addresses: `"Addresses": ["192.0.2.44/32",
    #     "192.0.2.0/24", "192.0.0.0/16"]`
    #
    #   * INVALID specification: `"Addresses": [""]` INVALID
    #
    #
    #
    #   [1]: https://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing
    #   @return [Array<String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/IPSet AWS API Documentation
    #
    class IPSet < Struct.new(
      :name,
      :id,
      :arn,
      :description,
      :ip_address_version,
      :addresses)
      SENSITIVE = []
      include Aws::Structure
    end

    # 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.
    #
    # <note markdown="1"> If the specified header isn't present in the request, WAF doesn't
    # apply the rule to the web request at all.
    #
    #  </note>
    #
    # This configuration is used only for IPSetReferenceStatement. For
    # GeoMatchStatement and RateBasedStatement, use ForwardedIPConfig
    # instead.
    #
    # @!attribute [rw] header_name
    #   The name of the HTTP header to use for the IP address. For example,
    #   to use the X-Forwarded-For (XFF) header, set this to
    #   `X-Forwarded-For`.
    #
    #   <note markdown="1"> If the specified header isn't present in the request, WAF doesn't
    #   apply the rule to the web request at all.
    #
    #    </note>
    #   @return [String]
    #
    # @!attribute [rw] fallback_behavior
    #   The match status to assign to the web request if the request
    #   doesn't have a valid IP address in the specified position.
    #
    #   <note markdown="1"> If the specified header isn't present in the request, WAF doesn't
    #   apply the rule to the web request at all.
    #
    #    </note>
    #
    #   You can specify the following fallback behaviors:
    #
    #   * `MATCH` - Treat the web request as matching the rule statement.
    #     WAF applies the rule action to the request.
    #
    #   * `NO_MATCH` - Treat the web request as not matching the rule
    #     statement.
    #   @return [String]
    #
    # @!attribute [rw] position
    #   The position in the header to search for the IP address. The header
    #   can contain IP addresses of the original client and also of proxies.
    #   For example, the header value could be `10.1.1.1, 127.0.0.0,
    #   10.10.10.10` where the first IP address identifies the original
    #   client and the rest identify proxies that the request went through.
    #
    #   The options for this setting are the following:
    #
    #   * FIRST - Inspect the first IP address in the list of IP addresses
    #     in the header. This is usually the client's original IP.
    #
    #   * LAST - Inspect the last IP address in the list of IP addresses in
    #     the header.
    #
    #   * ANY - Inspect all IP addresses in the header for a match. If the
    #     header contains more than 10 IP addresses, WAF inspects the last
    #     10.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/IPSetForwardedIPConfig AWS API Documentation
    #
    class IPSetForwardedIPConfig < Struct.new(
      :header_name,
      :fallback_behavior,
      :position)
      SENSITIVE = []
      include Aws::Structure
    end

    # 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.
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the IPSet that this statement
    #   references.
    #   @return [String]
    #
    # @!attribute [rw] ip_set_forwarded_ip_config
    #   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.
    #
    #   <note markdown="1"> If the specified header isn't present in the request, WAF doesn't
    #   apply the rule to the web request at all.
    #
    #    </note>
    #   @return [Types::IPSetForwardedIPConfig]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/IPSetReferenceStatement AWS API Documentation
    #
    class IPSetReferenceStatement < Struct.new(
      :arn,
      :ip_set_forwarded_ip_config)
      SENSITIVE = []
      include Aws::Structure
    end

    # High-level information about an IPSet, returned by operations like
    # create and list. This provides information like the ID, that you can
    # use to retrieve and manage an `IPSet`, and the ARN, that you provide
    # to the IPSetReferenceStatement to use the address set in a Rule.
    #
    # @!attribute [rw] name
    #   The name of the IP set. You cannot change the name of an `IPSet`
    #   after you create it.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the set. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   A description of the IP set that helps with identification.
    #   @return [String]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the entity.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/IPSetSummary AWS API Documentation
    #
    class IPSetSummary < Struct.new(
      :name,
      :id,
      :description,
      :lock_token,
      :arn)
      SENSITIVE = []
      include Aws::Structure
    end

    # Used for CAPTCHA and challenge token settings. Determines how long a
    # `CAPTCHA` or challenge timestamp remains valid after WAF updates it
    # for a successful `CAPTCHA` or challenge response.
    #
    # @!attribute [rw] immunity_time
    #   The amount of time, in seconds, that a `CAPTCHA` or challenge
    #   timestamp is considered valid by WAF. The default setting is 300.
    #
    #   For the Challenge action, the minimum setting is 300.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ImmunityTimeProperty AWS API Documentation
    #
    class ImmunityTimeProperty < Struct.new(
      :immunity_time)
      SENSITIVE = []
      include Aws::Structure
    end

    # Available for use with Amazon CloudFront distributions and Application
    # Load Balancers. Match against the request's JA3 fingerprint. The JA3
    # fingerprint is a 32-character hash derived from the TLS Client Hello
    # of an incoming request. This fingerprint serves as a unique identifier
    # for the client's TLS configuration. WAF calculates and logs this
    # fingerprint for each request that has enough TLS Client Hello
    # information for the calculation. Almost all web requests include this
    # information.
    #
    # <note markdown="1"> You can use this choice only with a string match `ByteMatchStatement`
    # with the `PositionalConstraint` set to `EXACTLY`.
    #
    #  </note>
    #
    # You can obtain the JA3 fingerprint for client requests from the web
    # ACL logs. If WAF is able to calculate the fingerprint, it includes it
    # in the logs. For information about the logging fields, see [Log
    # fields][1] in the *WAF Developer Guide*.
    #
    # Provide the JA3 fingerprint string from the logs in your string match
    # statement specification, to match with any future requests that have
    # the same TLS configuration.
    #
    #
    #
    # [1]: https://docs.aws.amazon.com/waf/latest/developerguide/logging-fields.html
    #
    # @!attribute [rw] fallback_behavior
    #   The match status to assign to the web request if the request
    #   doesn't have a JA3 fingerprint.
    #
    #   You can specify the following fallback behaviors:
    #
    #   * `MATCH` - Treat the web request as matching the rule statement.
    #     WAF applies the rule action to the request.
    #
    #   * `NO_MATCH` - Treat the web request as not matching the rule
    #     statement.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/JA3Fingerprint AWS API Documentation
    #
    class JA3Fingerprint < Struct.new(
      :fallback_behavior)
      SENSITIVE = []
      include Aws::Structure
    end

    # Inspect the body of the web request as JSON. The body immediately
    # follows the request headers.
    #
    # This is used to indicate the web request component to inspect, in the
    # FieldToMatch specification.
    #
    # Use the specifications in this object to indicate which parts of the
    # JSON body to inspect using the rule's inspection criteria. WAF
    # inspects only the parts of the JSON that result from the matches that
    # you indicate.
    #
    # Example JSON: `"JsonBody": { "MatchPattern": { "All": {} },
    # "MatchScope": "ALL" }`
    #
    # For additional information about this request component option, see
    # [JSON body][1] in the *WAF Developer Guide*.
    #
    #
    #
    # [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-rule-statement-fields-list.html#waf-rule-statement-request-component-json-body
    #
    # @!attribute [rw] match_pattern
    #   The patterns to look for in the JSON body. WAF inspects the results
    #   of these pattern matches against the rule inspection criteria.
    #   @return [Types::JsonMatchPattern]
    #
    # @!attribute [rw] match_scope
    #   The parts of the JSON to match against using the `MatchPattern`. If
    #   you specify `ALL`, WAF matches against keys and values.
    #
    #   `All` does not require a match to be found in the keys and a match
    #   to be found in the values. It requires a match to be found in the
    #   keys or the values or both. To require a match in the keys and in
    #   the values, use a logical `AND` statement to combine two match
    #   rules, one that inspects the keys and another that inspects the
    #   values.
    #   @return [String]
    #
    # @!attribute [rw] invalid_fallback_behavior
    #   What WAF should do if it fails to completely parse the JSON body.
    #   The options are the following:
    #
    #   * `EVALUATE_AS_STRING` - Inspect the body as plain text. WAF applies
    #     the text transformations and inspection criteria that you defined
    #     for the JSON inspection to the body text string.
    #
    #   * `MATCH` - Treat the web request as matching the rule statement.
    #     WAF applies the rule action to the request.
    #
    #   * `NO_MATCH` - Treat the web request as not matching the rule
    #     statement.
    #
    #   If you don't provide this setting, WAF parses and evaluates the
    #   content only up to the first parsing failure that it encounters.
    #
    #   <note markdown="1"> WAF parsing doesn't fully validate the input JSON string, so
    #   parsing can succeed even for invalid JSON. When parsing succeeds,
    #   WAF doesn't apply the fallback behavior. For more information, see
    #   [JSON body][1] in the *WAF Developer Guide*.
    #
    #    </note>
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-rule-statement-fields-list.html#waf-rule-statement-request-component-json-body
    #   @return [String]
    #
    # @!attribute [rw] oversize_handling
    #   What WAF should do if the body is larger than WAF can inspect.
    #
    #   WAF does not support inspecting the entire contents of the web
    #   request body if the body exceeds the limit for the resource type.
    #   When a web request body is larger than the limit, the underlying
    #   host service only forwards the contents that are within the limit to
    #   WAF for inspection.
    #
    #   * For Application Load Balancer and AppSync, the limit is fixed at 8
    #     KB (8,192 bytes).
    #
    #   * For CloudFront, API Gateway, Amazon Cognito, App Runner, and
    #     Verified Access, the default limit is 16 KB (16,384 bytes), and
    #     you can increase the limit for each resource type in the web ACL
    #     `AssociationConfig`, for additional processing fees.
    #
    #   The options for oversize handling are the following:
    #
    #   * `CONTINUE` - Inspect the available body contents normally,
    #     according to the rule inspection criteria.
    #
    #   * `MATCH` - Treat the web request as matching the rule statement.
    #     WAF applies the rule action to the request.
    #
    #   * `NO_MATCH` - Treat the web request as not matching the rule
    #     statement.
    #
    #   You can combine the `MATCH` or `NO_MATCH` settings for oversize
    #   handling with your rule and web ACL action settings, so that you
    #   block any request whose body is over the limit.
    #
    #   Default: `CONTINUE`
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/JsonBody AWS API Documentation
    #
    class JsonBody < Struct.new(
      :match_pattern,
      :match_scope,
      :invalid_fallback_behavior,
      :oversize_handling)
      SENSITIVE = []
      include Aws::Structure
    end

    # The patterns to look for in the JSON body. WAF inspects the results of
    # these pattern matches against the rule inspection criteria. This is
    # used with the FieldToMatch option `JsonBody`.
    #
    # @!attribute [rw] all
    #   Match all of the elements. See also `MatchScope` in JsonBody.
    #
    #   You must specify either this setting or the `IncludedPaths` setting,
    #   but not both.
    #   @return [Types::All]
    #
    # @!attribute [rw] included_paths
    #   Match only the specified include paths. See also `MatchScope` in
    #   JsonBody.
    #
    #   Provide the include paths using JSON Pointer syntax. For example,
    #   `"IncludedPaths": ["/dogs/0/name", "/dogs/1/name"]`. For information
    #   about this syntax, see the Internet Engineering Task Force (IETF)
    #   documentation [JavaScript Object Notation (JSON) Pointer][1].
    #
    #   You must specify either this setting or the `All` setting, but not
    #   both.
    #
    #   <note markdown="1"> Don't use this option to include all paths. Instead, use the `All`
    #   setting.
    #
    #    </note>
    #
    #
    #
    #   [1]: https://tools.ietf.org/html/rfc6901
    #   @return [Array<String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/JsonMatchPattern AWS API Documentation
    #
    class JsonMatchPattern < Struct.new(
      :all,
      :included_paths)
      SENSITIVE = []
      include Aws::Structure
    end

    # A single label container. This is used as an element of a label array
    # in multiple contexts, for example, in `RuleLabels` inside a Rule and
    # in `Labels` inside a SampledHTTPRequest.
    #
    # @!attribute [rw] name
    #   The label string.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/Label AWS API Documentation
    #
    class Label < Struct.new(
      :name)
      SENSITIVE = []
      include Aws::Structure
    end

    # 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, WAF performs the search for labels that
    # were added in the same context as the label match statement.
    #
    # @!attribute [rw] scope
    #   Specify whether you want to match using the label name or just the
    #   namespace.
    #   @return [String]
    #
    # @!attribute [rw] key
    #   The string to match against. The setting you provide for this
    #   depends on the match statement's `Scope` setting:
    #
    #   * If the `Scope` indicates `LABEL`, then this specification must
    #     include the name and can include any number of preceding namespace
    #     specifications and prefix up to providing the fully qualified
    #     label name.
    #
    #   * If the `Scope` indicates `NAMESPACE`, then this specification can
    #     include any number of contiguous namespace strings, and can
    #     include the entire label namespace prefix from the rule group or
    #     web ACL where the label originates.
    #
    #   Labels are case sensitive and components of a label must be
    #   separated by colon, for example `NS1:NS2:name`.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/LabelMatchStatement AWS API Documentation
    #
    class LabelMatchStatement < Struct.new(
      :scope,
      :key)
      SENSITIVE = []
      include Aws::Structure
    end

    # A single label name condition for a Condition in a logging filter.
    #
    # @!attribute [rw] label_name
    #   The label name that a log record must contain in order to meet the
    #   condition. This must be a fully qualified label name. 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.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/LabelNameCondition AWS API Documentation
    #
    class LabelNameCondition < Struct.new(
      :label_name)
      SENSITIVE = []
      include Aws::Structure
    end

    # List of labels used by one or more of the rules of a RuleGroup. This
    # summary object is used for the following rule group lists:
    #
    # * `AvailableLabels` - Labels that rules add to matching requests.
    #   These labels are defined in the `RuleLabels` for a Rule.
    #
    # * `ConsumedLabels` - Labels that rules match against. These labels are
    #   defined in a `LabelMatchStatement` specification, in the Statement
    #   definition of a rule.
    #
    # @!attribute [rw] name
    #   An individual label specification.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/LabelSummary AWS API Documentation
    #
    class LabelSummary < Struct.new(
      :name)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] limit
    #   The maximum number of objects that you want WAF to return for this
    #   request. If more objects are available, in the response, WAF
    #   provides a `NextMarker` value that you can use in a subsequent call
    #   to get the next batch of objects.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListAPIKeysRequest AWS API Documentation
    #
    class ListAPIKeysRequest < Struct.new(
      :scope,
      :next_marker,
      :limit)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] api_key_summaries
    #   The array of key summaries. If you specified a `Limit` in your
    #   request, this might not be the full list.
    #   @return [Array<Types::APIKeySummary>]
    #
    # @!attribute [rw] application_integration_url
    #   The CAPTCHA application integration URL, for use in your JavaScript
    #   implementation.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListAPIKeysResponse AWS API Documentation
    #
    class ListAPIKeysResponse < Struct.new(
      :next_marker,
      :api_key_summaries,
      :application_integration_url)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] vendor_name
    #   The name of the managed rule group vendor. You use this, along with
    #   the rule group name, to identify a rule group.
    #   @return [String]
    #
    # @!attribute [rw] name
    #   The name of the managed rule group. You use this, along with the
    #   vendor name, to identify the rule group.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] limit
    #   The maximum number of objects that you want WAF to return for this
    #   request. If more objects are available, in the response, WAF
    #   provides a `NextMarker` value that you can use in a subsequent call
    #   to get the next batch of objects.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListAvailableManagedRuleGroupVersionsRequest AWS API Documentation
    #
    class ListAvailableManagedRuleGroupVersionsRequest < Struct.new(
      :vendor_name,
      :name,
      :scope,
      :next_marker,
      :limit)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] versions
    #   The versions that are currently available for the specified managed
    #   rule group. If you specified a `Limit` in your request, this might
    #   not be the full list.
    #   @return [Array<Types::ManagedRuleGroupVersion>]
    #
    # @!attribute [rw] current_default_version
    #   The name of the version that's currently set as the default.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListAvailableManagedRuleGroupVersionsResponse AWS API Documentation
    #
    class ListAvailableManagedRuleGroupVersionsResponse < Struct.new(
      :next_marker,
      :versions,
      :current_default_version)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] limit
    #   The maximum number of objects that you want WAF to return for this
    #   request. If more objects are available, in the response, WAF
    #   provides a `NextMarker` value that you can use in a subsequent call
    #   to get the next batch of objects.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListAvailableManagedRuleGroupsRequest AWS API Documentation
    #
    class ListAvailableManagedRuleGroupsRequest < Struct.new(
      :scope,
      :next_marker,
      :limit)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] managed_rule_groups
    #   Array of managed rule groups that you can use. If you specified a
    #   `Limit` in your request, this might not be the full list.
    #   @return [Array<Types::ManagedRuleGroupSummary>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListAvailableManagedRuleGroupsResponse AWS API Documentation
    #
    class ListAvailableManagedRuleGroupsResponse < Struct.new(
      :next_marker,
      :managed_rule_groups)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] limit
    #   The maximum number of objects that you want WAF to return for this
    #   request. If more objects are available, in the response, WAF
    #   provides a `NextMarker` value that you can use in a subsequent call
    #   to get the next batch of objects.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListIPSetsRequest AWS API Documentation
    #
    class ListIPSetsRequest < Struct.new(
      :scope,
      :next_marker,
      :limit)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] ip_sets
    #   Array of IPSets. If you specified a `Limit` in your request, this
    #   might not be the full list.
    #   @return [Array<Types::IPSetSummary>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListIPSetsResponse AWS API Documentation
    #
    class ListIPSetsResponse < Struct.new(
      :next_marker,
      :ip_sets)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] limit
    #   The maximum number of objects that you want WAF to return for this
    #   request. If more objects are available, in the response, WAF
    #   provides a `NextMarker` value that you can use in a subsequent call
    #   to get the next batch of objects.
    #   @return [Integer]
    #
    # @!attribute [rw] log_scope
    #   The owner of the logging configuration, which must be set to
    #   `CUSTOMER` for the configurations that you manage.
    #
    #   The log scope `SECURITY_LAKE` indicates a configuration that is
    #   managed through Amazon Security Lake. You can use Security Lake to
    #   collect log and event data from various sources for normalization,
    #   analysis, and management. For information, see [Collecting data from
    #   Amazon Web Services services][1] in the *Amazon Security Lake user
    #   guide*.
    #
    #   Default: `CUSTOMER`
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/security-lake/latest/userguide/internal-sources.html
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListLoggingConfigurationsRequest AWS API Documentation
    #
    class ListLoggingConfigurationsRequest < Struct.new(
      :scope,
      :next_marker,
      :limit,
      :log_scope)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] logging_configurations
    #   Array of logging configurations. If you specified a `Limit` in your
    #   request, this might not be the full list.
    #   @return [Array<Types::LoggingConfiguration>]
    #
    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListLoggingConfigurationsResponse AWS API Documentation
    #
    class ListLoggingConfigurationsResponse < Struct.new(
      :logging_configurations,
      :next_marker)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] limit
    #   The maximum number of objects that you want WAF to return for this
    #   request. If more objects are available, in the response, WAF
    #   provides a `NextMarker` value that you can use in a subsequent call
    #   to get the next batch of objects.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListManagedRuleSetsRequest AWS API Documentation
    #
    class ListManagedRuleSetsRequest < Struct.new(
      :scope,
      :next_marker,
      :limit)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] managed_rule_sets
    #   Your managed rule sets. If you specified a `Limit` in your request,
    #   this might not be the full list.
    #   @return [Array<Types::ManagedRuleSetSummary>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListManagedRuleSetsResponse AWS API Documentation
    #
    class ListManagedRuleSetsResponse < Struct.new(
      :next_marker,
      :managed_rule_sets)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] platform
    #   The device platform to retrieve the list for.
    #   @return [String]
    #
    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] limit
    #   The maximum number of objects that you want WAF to return for this
    #   request. If more objects are available, in the response, WAF
    #   provides a `NextMarker` value that you can use in a subsequent call
    #   to get the next batch of objects.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListMobileSdkReleasesRequest AWS API Documentation
    #
    class ListMobileSdkReleasesRequest < Struct.new(
      :platform,
      :next_marker,
      :limit)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] release_summaries
    #   The high level information for the available SDK releases. If you
    #   specified a `Limit` in your request, this might not be the full
    #   list.
    #   @return [Array<Types::ReleaseSummary>]
    #
    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListMobileSdkReleasesResponse AWS API Documentation
    #
    class ListMobileSdkReleasesResponse < Struct.new(
      :release_summaries,
      :next_marker)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] limit
    #   The maximum number of objects that you want WAF to return for this
    #   request. If more objects are available, in the response, WAF
    #   provides a `NextMarker` value that you can use in a subsequent call
    #   to get the next batch of objects.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListRegexPatternSetsRequest AWS API Documentation
    #
    class ListRegexPatternSetsRequest < Struct.new(
      :scope,
      :next_marker,
      :limit)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] regex_pattern_sets
    #   Array of regex pattern sets. If you specified a `Limit` in your
    #   request, this might not be the full list.
    #   @return [Array<Types::RegexPatternSetSummary>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListRegexPatternSetsResponse AWS API Documentation
    #
    class ListRegexPatternSetsResponse < Struct.new(
      :next_marker,
      :regex_pattern_sets)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] web_acl_arn
    #   The Amazon Resource Name (ARN) of the web ACL.
    #   @return [String]
    #
    # @!attribute [rw] resource_type
    #   Used for web ACLs that are scoped for regional applications. A
    #   regional application can be an Application Load Balancer (ALB), an
    #   Amazon API Gateway REST API, an AppSync GraphQL API, an Amazon
    #   Cognito user pool, an App Runner service, or an Amazon Web Services
    #   Verified Access instance.
    #
    #   <note markdown="1"> If you don't provide a resource type, the call uses the resource
    #   type `APPLICATION_LOAD_BALANCER`.
    #
    #    </note>
    #
    #   Default: `APPLICATION_LOAD_BALANCER`
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListResourcesForWebACLRequest AWS API Documentation
    #
    class ListResourcesForWebACLRequest < Struct.new(
      :web_acl_arn,
      :resource_type)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] resource_arns
    #   The array of Amazon Resource Names (ARNs) of the associated
    #   resources.
    #   @return [Array<String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListResourcesForWebACLResponse AWS API Documentation
    #
    class ListResourcesForWebACLResponse < Struct.new(
      :resource_arns)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] limit
    #   The maximum number of objects that you want WAF to return for this
    #   request. If more objects are available, in the response, WAF
    #   provides a `NextMarker` value that you can use in a subsequent call
    #   to get the next batch of objects.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListRuleGroupsRequest AWS API Documentation
    #
    class ListRuleGroupsRequest < Struct.new(
      :scope,
      :next_marker,
      :limit)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] rule_groups
    #   Array of rule groups. If you specified a `Limit` in your request,
    #   this might not be the full list.
    #   @return [Array<Types::RuleGroupSummary>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListRuleGroupsResponse AWS API Documentation
    #
    class ListRuleGroupsResponse < Struct.new(
      :next_marker,
      :rule_groups)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] limit
    #   The maximum number of objects that you want WAF to return for this
    #   request. If more objects are available, in the response, WAF
    #   provides a `NextMarker` value that you can use in a subsequent call
    #   to get the next batch of objects.
    #   @return [Integer]
    #
    # @!attribute [rw] resource_arn
    #   The Amazon Resource Name (ARN) of the resource.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListTagsForResourceRequest AWS API Documentation
    #
    class ListTagsForResourceRequest < Struct.new(
      :next_marker,
      :limit,
      :resource_arn)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] tag_info_for_resource
    #   The collection of tagging definitions for the resource. If you
    #   specified a `Limit` in your request, this might not be the full
    #   list.
    #   @return [Types::TagInfoForResource]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListTagsForResourceResponse AWS API Documentation
    #
    class ListTagsForResourceResponse < Struct.new(
      :next_marker,
      :tag_info_for_resource)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] limit
    #   The maximum number of objects that you want WAF to return for this
    #   request. If more objects are available, in the response, WAF
    #   provides a `NextMarker` value that you can use in a subsequent call
    #   to get the next batch of objects.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListWebACLsRequest AWS API Documentation
    #
    class ListWebACLsRequest < Struct.new(
      :scope,
      :next_marker,
      :limit)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_marker
    #   When you request a list of objects with a `Limit` setting, if the
    #   number of objects that are still available for retrieval exceeds the
    #   limit, WAF returns a `NextMarker` value in the response. To retrieve
    #   the next batch of objects, provide the marker from the prior call in
    #   your next request.
    #   @return [String]
    #
    # @!attribute [rw] web_acls
    #   Array of web ACLs. If you specified a `Limit` in your request, this
    #   might not be the full list.
    #   @return [Array<Types::WebACLSummary>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ListWebACLsResponse AWS API Documentation
    #
    class ListWebACLsResponse < Struct.new(
      :next_marker,
      :web_acls)
      SENSITIVE = []
      include Aws::Structure
    end

    # Defines an association between logging destinations and a web ACL
    # resource, for logging from WAF. As part of the association, you can
    # specify parts of the standard logging fields to keep out of the logs
    # and you can specify filters so that you log only a subset of the
    # logging records.
    #
    # <note markdown="1"> You can define one logging destination per web ACL.
    #
    #  </note>
    #
    # You can access information about the traffic that WAF inspects using
    # the following steps:
    #
    # 1.  Create your logging destination. You can use an Amazon CloudWatch
    #     Logs log group, an Amazon Simple Storage Service (Amazon S3)
    #     bucket, or an Amazon Kinesis Data Firehose.
    #
    #     The name that you give the destination must start with
    #     `aws-waf-logs-`. Depending on the type of destination, you might
    #     need to configure additional settings or permissions.
    #
    #     For configuration requirements and pricing information for each
    #     destination type, see [Logging web ACL traffic][1] in the *WAF
    #     Developer Guide*.
    #
    # 2.  Associate your logging destination to your web ACL using a
    #     `PutLoggingConfiguration` request.
    #
    # When you successfully enable logging using a `PutLoggingConfiguration`
    # request, WAF creates an additional role or policy that is required to
    # write logs to the logging destination. For an Amazon CloudWatch Logs
    # log group, WAF creates a resource policy on the log group. For an
    # Amazon S3 bucket, WAF creates a bucket policy. For an Amazon Kinesis
    # Data Firehose, WAF creates a service-linked role.
    #
    # For additional information about web ACL logging, see [Logging web ACL
    # traffic information][1] in the *WAF Developer Guide*.
    #
    #
    #
    # [1]: https://docs.aws.amazon.com/waf/latest/developerguide/logging.html
    #
    # @!attribute [rw] resource_arn
    #   The Amazon Resource Name (ARN) of the web ACL that you want to
    #   associate with `LogDestinationConfigs`.
    #   @return [String]
    #
    # @!attribute [rw] log_destination_configs
    #   The logging destination configuration that you want to associate
    #   with the web ACL.
    #
    #   <note markdown="1"> You can associate one logging destination to a web ACL.
    #
    #    </note>
    #   @return [Array<String>]
    #
    # @!attribute [rw] redacted_fields
    #   The parts of the request that you want to keep out of the logs.
    #
    #   For example, if you redact the `SingleHeader` field, the `HEADER`
    #   field in the logs will be `REDACTED` for all rules that use the
    #   `SingleHeader` `FieldToMatch` setting.
    #
    #   Redaction applies only to the component that's specified in the
    #   rule's `FieldToMatch` setting, so the `SingleHeader` redaction
    #   doesn't apply to rules that use the `Headers` `FieldToMatch`.
    #
    #   <note markdown="1"> You can specify only the following fields for redaction: `UriPath`,
    #   `QueryString`, `SingleHeader`, and `Method`.
    #
    #    </note>
    #
    #   <note markdown="1"> This setting has no impact on request sampling. With request
    #   sampling, the only way to exclude fields is by disabling sampling in
    #   the web ACL visibility configuration.
    #
    #    </note>
    #   @return [Array<Types::FieldToMatch>]
    #
    # @!attribute [rw] managed_by_firewall_manager
    #   Indicates whether the logging configuration was created by Firewall
    #   Manager, as part of an WAF policy configuration. If true, only
    #   Firewall Manager can modify or delete the configuration.
    #
    #   The logging configuration can be created by Firewall Manager for use
    #   with any web ACL that Firewall Manager is using for an WAF policy.
    #   Web ACLs that Firewall Manager creates and uses have their
    #   `ManagedByFirewallManager` property set to true. Web ACLs that were
    #   created by a customer account and then retrofitted by Firewall
    #   Manager for use by a policy have their
    #   `RetrofittedByFirewallManager` property set to true. For either
    #   case, any corresponding logging configuration will indicate
    #   `ManagedByFirewallManager`.
    #   @return [Boolean]
    #
    # @!attribute [rw] logging_filter
    #   Filtering that specifies which web requests are kept in the logs and
    #   which are dropped. You can filter on the rule action and on the web
    #   request labels that were applied by matching rules during web ACL
    #   evaluation.
    #   @return [Types::LoggingFilter]
    #
    # @!attribute [rw] log_type
    #   Used to distinguish between various logging options. Currently,
    #   there is one option.
    #
    #   Default: `WAF_LOGS`
    #   @return [String]
    #
    # @!attribute [rw] log_scope
    #   The owner of the logging configuration, which must be set to
    #   `CUSTOMER` for the configurations that you manage.
    #
    #   The log scope `SECURITY_LAKE` indicates a configuration that is
    #   managed through Amazon Security Lake. You can use Security Lake to
    #   collect log and event data from various sources for normalization,
    #   analysis, and management. For information, see [Collecting data from
    #   Amazon Web Services services][1] in the *Amazon Security Lake user
    #   guide*.
    #
    #   Default: `CUSTOMER`
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/security-lake/latest/userguide/internal-sources.html
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/LoggingConfiguration AWS API Documentation
    #
    class LoggingConfiguration < Struct.new(
      :resource_arn,
      :log_destination_configs,
      :redacted_fields,
      :managed_by_firewall_manager,
      :logging_filter,
      :log_type,
      :log_scope)
      SENSITIVE = []
      include Aws::Structure
    end

    # Filtering that specifies which web requests are kept in the logs and
    # which are dropped, defined for a web ACL's LoggingConfiguration.
    #
    # You can filter on the rule action and on the web request labels that
    # were applied by matching rules during web ACL evaluation.
    #
    # @!attribute [rw] filters
    #   The filters that you want to apply to the logs.
    #   @return [Array<Types::Filter>]
    #
    # @!attribute [rw] default_behavior
    #   Default handling for logs that don't match any of the specified
    #   filtering conditions.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/LoggingFilter AWS API Documentation
    #
    class LoggingFilter < Struct.new(
      :filters,
      :default_behavior)
      SENSITIVE = []
      include Aws::Structure
    end

    # The properties of a managed product, such as an Amazon Web Services
    # Managed Rules rule group or an Amazon Web Services Marketplace managed
    # rule group.
    #
    # @!attribute [rw] vendor_name
    #   The name of the managed rule group vendor. You use this, along with
    #   the rule group name, to identify a rule group.
    #   @return [String]
    #
    # @!attribute [rw] managed_rule_set_name
    #   The name of the managed rule group. For example,
    #   `AWSManagedRulesAnonymousIpList` or `AWSManagedRulesATPRuleSet`.
    #   @return [String]
    #
    # @!attribute [rw] product_id
    #   A unique identifier for the rule group. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @!attribute [rw] product_link
    #   For Amazon Web Services Marketplace managed rule groups only, the
    #   link to the rule group product page.
    #   @return [String]
    #
    # @!attribute [rw] product_title
    #   The display name for the managed rule group. For example, `Anonymous
    #   IP list` or `Account takeover prevention`.
    #   @return [String]
    #
    # @!attribute [rw] product_description
    #   A short description of the managed rule group.
    #   @return [String]
    #
    # @!attribute [rw] sns_topic_arn
    #   The Amazon resource name (ARN) of the Amazon Simple Notification
    #   Service SNS topic that's used to provide notification of changes to
    #   the managed rule group. You can subscribe to the SNS topic to
    #   receive notifications when the managed rule group is modified, such
    #   as for new versions and for version expiration. For more
    #   information, see the [Amazon Simple Notification Service Developer
    #   Guide][1].
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/sns/latest/dg/welcome.html
    #   @return [String]
    #
    # @!attribute [rw] is_versioning_supported
    #   Indicates whether the rule group is versioned.
    #   @return [Boolean]
    #
    # @!attribute [rw] is_advanced_managed_rule_set
    #   Indicates whether the rule group provides an advanced set of
    #   protections, such as the the Amazon Web Services Managed Rules rule
    #   groups that are used for WAF intelligent threat mitigation.
    #   @return [Boolean]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ManagedProductDescriptor AWS API Documentation
    #
    class ManagedProductDescriptor < Struct.new(
      :vendor_name,
      :managed_rule_set_name,
      :product_id,
      :product_link,
      :product_title,
      :product_description,
      :sns_topic_arn,
      :is_versioning_supported,
      :is_advanced_managed_rule_set)
      SENSITIVE = []
      include Aws::Structure
    end

    # Additional information that's used by a managed rule group. Many
    # managed rule groups don't require this.
    #
    # The rule groups used for intelligent threat mitigation require
    # additional configuration:
    #
    # * Use the `AWSManagedRulesACFPRuleSet` configuration object to
    #   configure the account creation fraud prevention managed rule group.
    #   The configuration includes the registration and sign-up pages of
    #   your application and the locations in the account creation request
    #   payload of data, such as the user email and phone number fields.
    #
    # * Use the `AWSManagedRulesATPRuleSet` configuration object to
    #   configure the account takeover prevention managed rule group. The
    #   configuration includes the sign-in page of your application and the
    #   locations in the login request payload of data such as the username
    #   and password.
    #
    # * Use the `AWSManagedRulesBotControlRuleSet` configuration object to
    #   configure the protection level that you want the Bot Control rule
    #   group to use.
    #
    # For example specifications, see the examples section of CreateWebACL.
    #
    # @!attribute [rw] login_path
    #   <note markdown="1"> Instead of this setting, provide your configuration under
    #   `AWSManagedRulesATPRuleSet`.
    #
    #    </note>
    #   @return [String]
    #
    # @!attribute [rw] payload_type
    #   <note markdown="1"> Instead of this setting, provide your configuration under the
    #   request inspection configuration for `AWSManagedRulesATPRuleSet` or
    #   `AWSManagedRulesACFPRuleSet`.
    #
    #    </note>
    #   @return [String]
    #
    # @!attribute [rw] username_field
    #   <note markdown="1"> Instead of this setting, provide your configuration under the
    #   request inspection configuration for `AWSManagedRulesATPRuleSet` or
    #   `AWSManagedRulesACFPRuleSet`.
    #
    #    </note>
    #   @return [Types::UsernameField]
    #
    # @!attribute [rw] password_field
    #   <note markdown="1"> Instead of this setting, provide your configuration under the
    #   request inspection configuration for `AWSManagedRulesATPRuleSet` or
    #   `AWSManagedRulesACFPRuleSet`.
    #
    #    </note>
    #   @return [Types::PasswordField]
    #
    # @!attribute [rw] aws_managed_rules_bot_control_rule_set
    #   Additional configuration for using the Bot Control managed rule
    #   group. Use this to specify the inspection level that you want to
    #   use. For information about using the Bot Control managed rule group,
    #   see [WAF Bot Control rule group][1] and [WAF Bot Control][2] in the
    #   *WAF Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/aws-managed-rule-groups-bot.html
    #   [2]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-bot-control.html
    #   @return [Types::AWSManagedRulesBotControlRuleSet]
    #
    # @!attribute [rw] aws_managed_rules_atp_rule_set
    #   Additional configuration for using the account takeover prevention
    #   (ATP) managed rule group, `AWSManagedRulesATPRuleSet`. Use this to
    #   provide login request information to the rule group. For web ACLs
    #   that protect CloudFront distributions, use this to also provide the
    #   information about how your distribution responds to login requests.
    #
    #   This configuration replaces the individual configuration fields in
    #   `ManagedRuleGroupConfig` and provides additional feature
    #   configuration.
    #
    #   For information about using the ATP managed rule group, see [WAF
    #   Fraud Control account takeover prevention (ATP) rule group][1] and
    #   [WAF Fraud Control account takeover prevention (ATP)][2] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/aws-managed-rule-groups-atp.html
    #   [2]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-atp.html
    #   @return [Types::AWSManagedRulesATPRuleSet]
    #
    # @!attribute [rw] aws_managed_rules_acfp_rule_set
    #   Additional configuration for using the account creation fraud
    #   prevention (ACFP) managed rule group, `AWSManagedRulesACFPRuleSet`.
    #   Use this to provide account creation request information to the rule
    #   group. For web ACLs that protect CloudFront distributions, use this
    #   to also provide the information about how your distribution responds
    #   to account creation requests.
    #
    #   For information about using the ACFP managed rule group, see [WAF
    #   Fraud Control account creation fraud prevention (ACFP) rule
    #   group][1] and [WAF Fraud Control account creation fraud prevention
    #   (ACFP)][2] in the *WAF Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/aws-managed-rule-groups-acfp.html
    #   [2]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-acfp.html
    #   @return [Types::AWSManagedRulesACFPRuleSet]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ManagedRuleGroupConfig AWS API Documentation
    #
    class ManagedRuleGroupConfig < Struct.new(
      :login_path,
      :payload_type,
      :username_field,
      :password_field,
      :aws_managed_rules_bot_control_rule_set,
      :aws_managed_rules_atp_rule_set,
      :aws_managed_rules_acfp_rule_set)
      SENSITIVE = []
      include Aws::Structure
    end

    # A rule statement used to run the rules that are defined in a managed
    # rule group. To use this, provide the vendor name and the name of the
    # rule group in this statement. You can retrieve the required names by
    # calling ListAvailableManagedRuleGroups.
    #
    # You cannot nest a `ManagedRuleGroupStatement`, for example for use
    # inside a `NotStatement` or `OrStatement`. You cannot use a managed
    # rule group inside another rule group. You can only reference a managed
    # rule group as a top-level statement within a rule that you define in a
    # web ACL.
    #
    # <note markdown="1"> You are charged additional fees when you use the WAF Bot Control
    # managed rule group `AWSManagedRulesBotControlRuleSet`, the WAF Fraud
    # Control account takeover prevention (ATP) managed rule group
    # `AWSManagedRulesATPRuleSet`, or the WAF Fraud Control account creation
    # fraud prevention (ACFP) managed rule group
    # `AWSManagedRulesACFPRuleSet`. For more information, see [WAF
    # Pricing][1].
    #
    #  </note>
    #
    #
    #
    # [1]: http://aws.amazon.com/waf/pricing/
    #
    # @!attribute [rw] vendor_name
    #   The name of the managed rule group vendor. You use this, along with
    #   the rule group name, to identify a rule group.
    #   @return [String]
    #
    # @!attribute [rw] name
    #   The name of the managed rule group. You use this, along with the
    #   vendor name, to identify the rule group.
    #   @return [String]
    #
    # @!attribute [rw] version
    #   The version of the managed rule group to use. If you specify this,
    #   the version setting is fixed until you change it. If you don't
    #   specify this, WAF uses the vendor's default version, and then keeps
    #   the version at the vendor's default when the vendor updates the
    #   managed rule group settings.
    #   @return [String]
    #
    # @!attribute [rw] excluded_rules
    #   Rules in the referenced rule group whose actions are set to `Count`.
    #
    #   <note markdown="1"> Instead of this option, use `RuleActionOverrides`. It accepts any
    #   valid action setting, including `Count`.
    #
    #    </note>
    #   @return [Array<Types::ExcludedRule>]
    #
    # @!attribute [rw] scope_down_statement
    #   An optional nested statement that narrows the scope of the web
    #   requests that are evaluated by the managed rule group. Requests are
    #   only evaluated by the rule group if they match the scope-down
    #   statement. You can use any nestable Statement in the scope-down
    #   statement, and you can nest statements at any level, the same as you
    #   can for a rule statement.
    #   @return [Types::Statement]
    #
    # @!attribute [rw] managed_rule_group_configs
    #   Additional information that's used by a managed rule group. Many
    #   managed rule groups don't require this.
    #
    #   The rule groups used for intelligent threat mitigation require
    #   additional configuration:
    #
    #   * Use the `AWSManagedRulesACFPRuleSet` configuration object to
    #     configure the account creation fraud prevention managed rule
    #     group. The configuration includes the registration and sign-up
    #     pages of your application and the locations in the account
    #     creation request payload of data, such as the user email and phone
    #     number fields.
    #
    #   * Use the `AWSManagedRulesATPRuleSet` configuration object to
    #     configure the account takeover prevention managed rule group. The
    #     configuration includes the sign-in page of your application and
    #     the locations in the login request payload of data such as the
    #     username and password.
    #
    #   * Use the `AWSManagedRulesBotControlRuleSet` configuration object to
    #     configure the protection level that you want the Bot Control rule
    #     group to use.
    #   @return [Array<Types::ManagedRuleGroupConfig>]
    #
    # @!attribute [rw] rule_action_overrides
    #   Action settings to use in the place of the rule actions that are
    #   configured inside the rule group. You specify one override for each
    #   rule whose action you want to change.
    #
    #   You can use overrides for testing, for example you can override all
    #   of rule actions to `Count` and then monitor the resulting count
    #   metrics to understand how the rule group would handle your web
    #   traffic. You can also permanently override some or all actions, to
    #   modify how the rule group manages your web traffic.
    #   @return [Array<Types::RuleActionOverride>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ManagedRuleGroupStatement AWS API Documentation
    #
    class ManagedRuleGroupStatement < Struct.new(
      :vendor_name,
      :name,
      :version,
      :excluded_rules,
      :scope_down_statement,
      :managed_rule_group_configs,
      :rule_action_overrides)
      SENSITIVE = []
      include Aws::Structure
    end

    # High-level information about a managed rule group, returned by
    # ListAvailableManagedRuleGroups. This provides information like the
    # name and vendor name, that you provide when you add a
    # ManagedRuleGroupStatement to a web ACL. Managed rule groups include
    # Amazon Web Services Managed Rules rule groups and Amazon Web Services
    # Marketplace managed rule groups. To use any Amazon Web Services
    # Marketplace managed rule group, first subscribe to the rule group
    # through Amazon Web Services Marketplace.
    #
    # @!attribute [rw] vendor_name
    #   The name of the managed rule group vendor. You use this, along with
    #   the rule group name, to identify a rule group.
    #   @return [String]
    #
    # @!attribute [rw] name
    #   The name of the managed rule group. You use this, along with the
    #   vendor name, to identify the rule group.
    #   @return [String]
    #
    # @!attribute [rw] versioning_supported
    #   Indicates whether the managed rule group is versioned. If it is, you
    #   can retrieve the versions list by calling
    #   ListAvailableManagedRuleGroupVersions.
    #   @return [Boolean]
    #
    # @!attribute [rw] description
    #   The description of the managed rule group, provided by Amazon Web
    #   Services Managed Rules or the Amazon Web Services Marketplace seller
    #   who manages it.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ManagedRuleGroupSummary AWS API Documentation
    #
    class ManagedRuleGroupSummary < Struct.new(
      :vendor_name,
      :name,
      :versioning_supported,
      :description)
      SENSITIVE = []
      include Aws::Structure
    end

    # Describes a single version of a managed rule group.
    #
    # @!attribute [rw] name
    #   The version name.
    #   @return [String]
    #
    # @!attribute [rw] last_update_timestamp
    #   The date and time that the managed rule group owner updated the rule
    #   group version information.
    #   @return [Time]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ManagedRuleGroupVersion AWS API Documentation
    #
    class ManagedRuleGroupVersion < Struct.new(
      :name,
      :last_update_timestamp)
      SENSITIVE = []
      include Aws::Structure
    end

    # A set of rules that is managed by Amazon Web Services and Amazon Web
    # Services Marketplace sellers to provide versioned managed rule groups
    # for customers of WAF.
    #
    # <note markdown="1"> This is intended for use only by vendors of managed rule sets. Vendors
    # are Amazon Web Services and Amazon Web Services Marketplace sellers.
    #
    #  Vendors, you can use the managed rule set APIs to provide controlled
    # rollout of your versioned managed rule group offerings for your
    # customers. The APIs are `ListManagedRuleSets`, `GetManagedRuleSet`,
    # `PutManagedRuleSetVersions`, and
    # `UpdateManagedRuleSetVersionExpiryDate`.
    #
    #  </note>
    #
    # @!attribute [rw] name
    #   The name of the managed rule set. You use this, along with the rule
    #   set ID, to identify the rule set.
    #
    #   This name is assigned to the corresponding managed rule group, which
    #   your customers can access and use.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the managed rule set. The ID is returned in
    #   the responses to commands like `list`. You provide it to operations
    #   like `get` and `update`.
    #   @return [String]
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the entity.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   A description of the set that helps with identification.
    #   @return [String]
    #
    # @!attribute [rw] published_versions
    #   The versions of this managed rule set that are available for use by
    #   customers.
    #   @return [Hash<String,Types::ManagedRuleSetVersion>]
    #
    # @!attribute [rw] recommended_version
    #   The version that you would like your customers to use.
    #   @return [String]
    #
    # @!attribute [rw] label_namespace
    #   The label namespace prefix for the managed rule groups that are
    #   offered to customers from this managed rule set. All labels that are
    #   added by rules in the managed rule group have this prefix.
    #
    #   * The syntax for the label namespace prefix for a managed rule group
    #     is the following:
    #
    #     `awswaf:managed:<vendor>:<rule group name>`:
    #
    #   * When a rule with a label matches a web request, WAF adds the fully
    #     qualified label to the request. A fully qualified label is made up
    #     of the label namespace from the rule group or web ACL where the
    #     rule is defined and the label from the rule, separated by a colon:
    #
    #     `<label namespace>:<label from rule>`
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ManagedRuleSet AWS API Documentation
    #
    class ManagedRuleSet < Struct.new(
      :name,
      :id,
      :arn,
      :description,
      :published_versions,
      :recommended_version,
      :label_namespace)
      SENSITIVE = []
      include Aws::Structure
    end

    # High-level information for a managed rule set.
    #
    # <note markdown="1"> This is intended for use only by vendors of managed rule sets. Vendors
    # are Amazon Web Services and Amazon Web Services Marketplace sellers.
    #
    #  Vendors, you can use the managed rule set APIs to provide controlled
    # rollout of your versioned managed rule group offerings for your
    # customers. The APIs are `ListManagedRuleSets`, `GetManagedRuleSet`,
    # `PutManagedRuleSetVersions`, and
    # `UpdateManagedRuleSetVersionExpiryDate`.
    #
    #  </note>
    #
    # @!attribute [rw] name
    #   The name of the managed rule set. You use this, along with the rule
    #   set ID, to identify the rule set.
    #
    #   This name is assigned to the corresponding managed rule group, which
    #   your customers can access and use.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the managed rule set. The ID is returned in
    #   the responses to commands like `list`. You provide it to operations
    #   like `get` and `update`.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   A description of the set that helps with identification.
    #   @return [String]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the entity.
    #   @return [String]
    #
    # @!attribute [rw] label_namespace
    #   The label namespace prefix for the managed rule groups that are
    #   offered to customers from this managed rule set. All labels that are
    #   added by rules in the managed rule group have this prefix.
    #
    #   * The syntax for the label namespace prefix for a managed rule group
    #     is the following:
    #
    #     `awswaf:managed:<vendor>:<rule group name>`:
    #
    #   * When a rule with a label matches a web request, WAF adds the fully
    #     qualified label to the request. A fully qualified label is made up
    #     of the label namespace from the rule group or web ACL where the
    #     rule is defined and the label from the rule, separated by a colon:
    #
    #     `<label namespace>:<label from rule>`
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ManagedRuleSetSummary AWS API Documentation
    #
    class ManagedRuleSetSummary < Struct.new(
      :name,
      :id,
      :description,
      :lock_token,
      :arn,
      :label_namespace)
      SENSITIVE = []
      include Aws::Structure
    end

    # Information for a single version of a managed rule set.
    #
    # <note markdown="1"> This is intended for use only by vendors of managed rule sets. Vendors
    # are Amazon Web Services and Amazon Web Services Marketplace sellers.
    #
    #  Vendors, you can use the managed rule set APIs to provide controlled
    # rollout of your versioned managed rule group offerings for your
    # customers. The APIs are `ListManagedRuleSets`, `GetManagedRuleSet`,
    # `PutManagedRuleSetVersions`, and
    # `UpdateManagedRuleSetVersionExpiryDate`.
    #
    #  </note>
    #
    # @!attribute [rw] associated_rule_group_arn
    #   The Amazon Resource Name (ARN) of the vendor rule group that's used
    #   to define the published version of your managed rule group.
    #   @return [String]
    #
    # @!attribute [rw] capacity
    #   The web ACL capacity units (WCUs) required for this rule group.
    #
    #   WAF uses WCUs to calculate and control the operating resources that
    #   are used to run your rules, rule groups, and web ACLs. WAF
    #   calculates capacity differently for each rule type, to reflect the
    #   relative cost of each rule. Simple rules that cost little to run use
    #   fewer WCUs than more complex rules that use more processing power.
    #   Rule group capacity is fixed at creation, which helps users plan
    #   their web ACL WCU usage when they use a rule group. For more
    #   information, see [WAF web ACL capacity units (WCU)][1] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/aws-waf-capacity-units.html
    #   @return [Integer]
    #
    # @!attribute [rw] forecasted_lifetime
    #   The amount of time you expect this version of your managed rule
    #   group to last, in days.
    #   @return [Integer]
    #
    # @!attribute [rw] publish_timestamp
    #   The time that you first published this version.
    #
    #   Times are in Coordinated Universal Time (UTC) format. UTC format
    #   includes the special designator, Z. For example,
    #   "2016-09-27T14:50Z".
    #   @return [Time]
    #
    # @!attribute [rw] last_update_timestamp
    #   The last time that you updated this version.
    #
    #   Times are in Coordinated Universal Time (UTC) format. UTC format
    #   includes the special designator, Z. For example,
    #   "2016-09-27T14:50Z".
    #   @return [Time]
    #
    # @!attribute [rw] expiry_timestamp
    #   The time that this version is set to expire.
    #
    #   Times are in Coordinated Universal Time (UTC) format. UTC format
    #   includes the special designator, Z. For example,
    #   "2016-09-27T14:50Z".
    #   @return [Time]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ManagedRuleSetVersion AWS API Documentation
    #
    class ManagedRuleSetVersion < Struct.new(
      :associated_rule_group_arn,
      :capacity,
      :forecasted_lifetime,
      :publish_timestamp,
      :last_update_timestamp,
      :expiry_timestamp)
      SENSITIVE = []
      include Aws::Structure
    end

    # Inspect the HTTP method of the web request. The method indicates the
    # type of operation that the request is asking the origin to perform.
    #
    # This is used in the FieldToMatch specification for some web request
    # component types.
    #
    # JSON specification: `"Method": {}`
    #
    # @api private
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/Method AWS API Documentation
    #
    class Method < Aws::EmptyStructure; end

    # Information for a release of the mobile SDK, including release notes
    # and tags.
    #
    # The mobile SDK is not generally available. Customers who have access
    # to the mobile SDK can use it to establish and manage WAF tokens for
    # use in HTTP(S) requests from a mobile device to WAF. For more
    # information, see [WAF client application integration][1] in the *WAF
    # Developer Guide*.
    #
    #
    #
    # [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-application-integration.html
    #
    # @!attribute [rw] release_version
    #   The release version.
    #   @return [String]
    #
    # @!attribute [rw] timestamp
    #   The timestamp of the release.
    #   @return [Time]
    #
    # @!attribute [rw] release_notes
    #   Notes describing the release.
    #   @return [String]
    #
    # @!attribute [rw] tags
    #   Tags that are associated with the release.
    #   @return [Array<Types::Tag>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/MobileSdkRelease AWS API Documentation
    #
    class MobileSdkRelease < Struct.new(
      :release_version,
      :timestamp,
      :release_notes,
      :tags)
      SENSITIVE = []
      include Aws::Structure
    end

    # Specifies that WAF should do nothing. This is used for the
    # `OverrideAction` setting on a Rule when the rule uses a rule group
    # reference statement.
    #
    # This is used in the context of other settings, for example to specify
    # values for RuleAction and web ACL DefaultAction.
    #
    # JSON specification: `"None": {}`
    #
    # @api private
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/NoneAction AWS API Documentation
    #
    class NoneAction < Aws::EmptyStructure; end

    # A logical rule statement used to negate the results of another rule
    # statement. You provide one Statement within the `NotStatement`.
    #
    # @!attribute [rw] statement
    #   The statement to negate. You can use any statement that can be
    #   nested.
    #   @return [Types::Statement]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/NotStatement AWS API Documentation
    #
    class NotStatement < Struct.new(
      :statement)
      SENSITIVE = []
      include Aws::Structure
    end

    # A logical rule statement used to combine other rule statements with OR
    # logic. You provide more than one Statement within the `OrStatement`.
    #
    # @!attribute [rw] statements
    #   The statements to combine with OR logic. You can use any statements
    #   that can be nested.
    #   @return [Array<Types::Statement>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/OrStatement AWS API Documentation
    #
    class OrStatement < Struct.new(
      :statements)
      SENSITIVE = []
      include Aws::Structure
    end

    # The action to use in the place of the action that results from the
    # rule group evaluation. Set the override action to none to leave the
    # result of the rule group alone. Set it to count to override the result
    # to count only.
    #
    # You can only use this for rule statements that reference a rule group,
    # like `RuleGroupReferenceStatement` and `ManagedRuleGroupStatement`.
    #
    # <note markdown="1"> This option is usually set to none. It does not affect how the rules
    # in the rule group are evaluated. If you want the rules in the rule
    # group to only count matches, do not use this and instead use the rule
    # action override option, with `Count` action, in your rule group
    # reference statement settings.
    #
    #  </note>
    #
    # @!attribute [rw] count
    #   Override the rule group evaluation result to count only.
    #
    #   <note markdown="1"> This option is usually set to none. It does not affect how the rules
    #   in the rule group are evaluated. If you want the rules in the rule
    #   group to only count matches, do not use this and instead use the
    #   rule action override option, with `Count` action, in your rule group
    #   reference statement settings.
    #
    #    </note>
    #   @return [Types::CountAction]
    #
    # @!attribute [rw] none
    #   Don't override the rule group evaluation result. This is the most
    #   common setting.
    #   @return [Types::NoneAction]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/OverrideAction AWS API Documentation
    #
    class OverrideAction < Struct.new(
      :count,
      :none)
      SENSITIVE = []
      include Aws::Structure
    end

    # The name of the field in the request payload that contains your
    # customer's password.
    #
    # This data type is used in the `RequestInspection` and
    # `RequestInspectionACFP` data types.
    #
    # @!attribute [rw] identifier
    #   The name of the password field.
    #
    #   How you specify this depends on the request inspection payload type.
    #
    #   * For JSON payloads, specify the field name in JSON pointer syntax.
    #     For information about the JSON Pointer syntax, see the Internet
    #     Engineering Task Force (IETF) documentation [JavaScript Object
    #     Notation (JSON) Pointer][1].
    #
    #     For example, for the JSON payload `{ "form": { "password":
    #     "THE_PASSWORD" } }`, the password field specification is
    #     `/form/password`.
    #
    #   * For form encoded payload types, use the HTML form names.
    #
    #     For example, for an HTML form with the input element named
    #     `password1`, the password field specification is `password1`.
    #
    #
    #
    #   [1]: https://tools.ietf.org/html/rfc6901
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/PasswordField AWS API Documentation
    #
    class PasswordField < Struct.new(
      :identifier)
      SENSITIVE = []
      include Aws::Structure
    end

    # The name of a field in the request payload that contains part or all
    # of your customer's primary phone number.
    #
    # This data type is used in the `RequestInspectionACFP` data type.
    #
    # @!attribute [rw] identifier
    #   The name of a single primary phone number field.
    #
    #   How you specify the phone number fields depends on the request
    #   inspection payload type.
    #
    #   * For JSON payloads, specify the field identifiers in JSON pointer
    #     syntax. For information about the JSON Pointer syntax, see the
    #     Internet Engineering Task Force (IETF) documentation [JavaScript
    #     Object Notation (JSON) Pointer][1].
    #
    #     For example, for the JSON payload `{ "form": {
    #     "primaryphoneline1": "THE_PHONE1", "primaryphoneline2":
    #     "THE_PHONE2", "primaryphoneline3": "THE_PHONE3" } }`, the phone
    #     number field identifiers are `/form/primaryphoneline1`,
    #     `/form/primaryphoneline2`, and `/form/primaryphoneline3`.
    #
    #   * For form encoded payload types, use the HTML form names.
    #
    #     For example, for an HTML form with input elements named
    #     `primaryphoneline1`, `primaryphoneline2`, and `primaryphoneline3`,
    #     the phone number field identifiers are `primaryphoneline1`,
    #     `primaryphoneline2`, and `primaryphoneline3`.
    #
    #
    #
    #   [1]: https://tools.ietf.org/html/rfc6901
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/PhoneNumberField AWS API Documentation
    #
    class PhoneNumberField < Struct.new(
      :identifier)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] logging_configuration
    #   @return [Types::LoggingConfiguration]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/PutLoggingConfigurationRequest AWS API Documentation
    #
    class PutLoggingConfigurationRequest < Struct.new(
      :logging_configuration)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] logging_configuration
    #   @return [Types::LoggingConfiguration]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/PutLoggingConfigurationResponse AWS API Documentation
    #
    class PutLoggingConfigurationResponse < Struct.new(
      :logging_configuration)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] name
    #   The name of the managed rule set. You use this, along with the rule
    #   set ID, to identify the rule set.
    #
    #   This name is assigned to the corresponding managed rule group, which
    #   your customers can access and use.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the managed rule set. The ID is returned in
    #   the responses to commands like `list`. You provide it to operations
    #   like `get` and `update`.
    #   @return [String]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @!attribute [rw] recommended_version
    #   The version of the named managed rule group that you'd like your
    #   customers to choose, from among your version offerings.
    #   @return [String]
    #
    # @!attribute [rw] versions_to_publish
    #   The versions of the named managed rule group that you want to offer
    #   to your customers.
    #   @return [Hash<String,Types::VersionToPublish>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/PutManagedRuleSetVersionsRequest AWS API Documentation
    #
    class PutManagedRuleSetVersionsRequest < Struct.new(
      :name,
      :scope,
      :id,
      :lock_token,
      :recommended_version,
      :versions_to_publish)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/PutManagedRuleSetVersionsResponse AWS API Documentation
    #
    class PutManagedRuleSetVersionsResponse < Struct.new(
      :next_lock_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] resource_arn
    #   The Amazon Resource Name (ARN) of the RuleGroup to which you want to
    #   attach the policy.
    #   @return [String]
    #
    # @!attribute [rw] policy
    #   The policy to attach to the specified rule group.
    #
    #   The policy specifications must conform to the following:
    #
    #   * The policy must be composed using IAM Policy version 2012-10-17.
    #
    #   * The policy must include specifications for `Effect`, `Action`, and
    #     `Principal`.
    #
    #   * `Effect` must specify `Allow`.
    #
    #   * `Action` must specify `wafv2:CreateWebACL`, `wafv2:UpdateWebACL`,
    #     and `wafv2:PutFirewallManagerRuleGroups` and may optionally
    #     specify `wafv2:GetRuleGroup`. WAF rejects any extra actions or
    #     wildcard actions in the policy.
    #
    #   * The policy must not include a `Resource` parameter.
    #
    #   For more information, see [IAM Policies][1].
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies.html
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/PutPermissionPolicyRequest AWS API Documentation
    #
    class PutPermissionPolicyRequest < Struct.new(
      :resource_arn,
      :policy)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/PutPermissionPolicyResponse AWS API Documentation
    #
    class PutPermissionPolicyResponse < Aws::EmptyStructure; end

    # Inspect the query string of the web request. This is the part of a URL
    # that appears after a `?` character, if any.
    #
    # This is used in the FieldToMatch specification for some web request
    # component types.
    #
    # JSON specification: `"QueryString": {}`
    #
    # @api private
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/QueryString AWS API Documentation
    #
    class QueryString < Aws::EmptyStructure; end

    # A rate-based rule counts incoming requests and rate limits requests
    # when they are coming at too fast a rate. The rule categorizes requests
    # according to your aggregation criteria, collects them into aggregation
    # instances, and counts and rate limits the requests for each instance.
    #
    # <note markdown="1"> 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.
    #
    #  </note>
    #
    # 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:
    #
    # * IP address 10.1.1.1, HTTP method POST
    #
    # * IP address 10.1.1.1, HTTP method GET
    #
    # * IP address 127.0.0.0, HTTP method POST
    #
    # * IP address 10.1.1.1, HTTP method GET
    #
    # The rule would create different aggregation instances according to
    # your aggregation criteria, for example:
    #
    # * If the aggregation criteria is just the IP address, then each
    #   individual address is an aggregation instance, and WAF counts
    #   requests separately for each. The aggregation instances and request
    #   counts for our example would be the following:
    #
    #   * IP address 10.1.1.1: count 3
    #
    #   * IP address 127.0.0.0: count 1
    # * If the aggregation criteria is HTTP method, then each individual
    #   HTTP method is an aggregation instance. The aggregation instances
    #   and request counts for our example would be the following:
    #
    #   * HTTP method POST: count 2
    #
    #   * HTTP method GET: count 2
    # * If the aggregation criteria is IP address and HTTP method, then each
    #   IP address and each HTTP method would contribute to the combined
    #   aggregation instance. The aggregation instances and request counts
    #   for our example would be the following:
    #
    #   * IP address 10.1.1.1, HTTP method POST: count 1
    #
    #   * IP address 10.1.1.1, HTTP method GET: count 2
    #
    #   * IP address 127.0.0.0, HTTP method POST: count 1
    #
    # For any n-tuple of aggregation keys, each unique combination of values
    # for the keys defines a separate aggregation instance, which 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][1] in the *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 WAF is
    # currently rate limiting for a rule through the API call
    # `GetRateBasedStatementManagedKeys`. This option is not available for
    # other aggregation configurations.
    #
    # 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 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 WAF.
    #
    #
    #
    # [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-rate-based-rules.html
    #
    # @!attribute [rw] limit
    #   The limit on requests per 5-minute period for a single aggregation
    #   instance for the rate-based rule. If the rate-based statement
    #   includes a `ScopeDownStatement`, this limit is applied only to the
    #   requests that match the statement.
    #
    #   Examples:
    #
    #   * If you aggregate on just the IP address, this is the limit on
    #     requests from any single IP address.
    #
    #   * If you aggregate on the HTTP method and the query argument name
    #     "city", then this is the limit on requests for any single
    #     method, city pair.
    #   @return [Integer]
    #
    # @!attribute [rw] evaluation_window_sec
    #   The amount of time, in seconds, that WAF should include in its
    #   request counts, looking back from the current time. For example, for
    #   a setting of 120, when WAF checks the rate, it counts the requests
    #   for the 2 minutes immediately preceding the current time. Valid
    #   settings are 60, 120, 300, and 600.
    #
    #   This setting doesn't determine how often WAF checks the rate, but
    #   how far back it looks each time it checks. WAF checks the rate about
    #   every 10 seconds.
    #
    #   Default: `300` (5 minutes)
    #   @return [Integer]
    #
    # @!attribute [rw] aggregate_key_type
    #   Setting that indicates how to aggregate the request counts.
    #
    #   <note markdown="1"> Web requests that are missing any of the components specified in the
    #   aggregation keys are omitted from the rate-based rule evaluation and
    #   handling.
    #
    #    </note>
    #
    #   * `CONSTANT` - Count and limit the requests that match the
    #     rate-based rule's scope-down statement. With this option, the
    #     counted requests aren't further aggregated. The scope-down
    #     statement is the only specification used. When the count of all
    #     requests that satisfy the scope-down statement goes over the
    #     limit, WAF applies the rule action to all requests that satisfy
    #     the scope-down statement.
    #
    #     With this option, you must configure the `ScopeDownStatement`
    #     property.
    #
    #   * `CUSTOM_KEYS` - Aggregate the request counts using one or more web
    #     request components as the aggregate keys.
    #
    #     With this option, you must specify the aggregate keys in the
    #     `CustomKeys` property.
    #
    #     To aggregate on only the IP address or only the forwarded IP
    #     address, don't use custom keys. Instead, set the aggregate key
    #     type to `IP` or `FORWARDED_IP`.
    #
    #   * `FORWARDED_IP` - Aggregate the request counts on the first IP
    #     address in an HTTP header.
    #
    #     With this option, you must specify the header to use in the
    #     `ForwardedIPConfig` property.
    #
    #     To aggregate on a combination of the forwarded IP address with
    #     other aggregate keys, use `CUSTOM_KEYS`.
    #
    #   * `IP` - Aggregate the request counts on the IP address from the web
    #     request origin.
    #
    #     To aggregate on a combination of the IP address with other
    #     aggregate keys, use `CUSTOM_KEYS`.
    #   @return [String]
    #
    # @!attribute [rw] scope_down_statement
    #   An optional nested statement that narrows the scope of the web
    #   requests that are evaluated and managed by the rate-based statement.
    #   When you use a scope-down statement, the rate-based rule only tracks
    #   and rate limits requests that match the scope-down statement. You
    #   can use any nestable Statement in the scope-down statement, and you
    #   can nest statements at any level, the same as you can for a rule
    #   statement.
    #   @return [Types::Statement]
    #
    # @!attribute [rw] forwarded_ip_config
    #   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.
    #
    #   <note markdown="1"> If the specified header isn't present in the request, WAF doesn't
    #   apply the rule to the web request at all.
    #
    #    </note>
    #
    #   This is required if you specify a forwarded IP in the rule's
    #   aggregate key settings.
    #   @return [Types::ForwardedIPConfig]
    #
    # @!attribute [rw] custom_keys
    #   Specifies the aggregate keys to use in a rate-base rule.
    #   @return [Array<Types::RateBasedStatementCustomKey>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RateBasedStatement AWS API Documentation
    #
    class RateBasedStatement < Struct.new(
      :limit,
      :evaluation_window_sec,
      :aggregate_key_type,
      :scope_down_statement,
      :forwarded_ip_config,
      :custom_keys)
      SENSITIVE = []
      include Aws::Structure
    end

    # Specifies a single custom aggregate key for a rate-base rule.
    #
    # <note markdown="1"> Web requests that are missing any of the components specified in the
    # aggregation keys are omitted from the rate-based rule evaluation and
    # handling.
    #
    #  </note>
    #
    # @!attribute [rw] header
    #   Use the value of a header in the request as an aggregate key. Each
    #   distinct value in the header contributes to the aggregation
    #   instance. If you use a single header as your custom key, then each
    #   value fully defines an aggregation instance.
    #   @return [Types::RateLimitHeader]
    #
    # @!attribute [rw] cookie
    #   Use the value of a cookie in the request as an aggregate key. Each
    #   distinct value in the cookie contributes to the aggregation
    #   instance. If you use a single cookie as your custom key, then each
    #   value fully defines an aggregation instance.
    #   @return [Types::RateLimitCookie]
    #
    # @!attribute [rw] query_argument
    #   Use the specified query argument as an aggregate key. Each distinct
    #   value for the named query argument contributes to the aggregation
    #   instance. If you use a single query argument as your custom key,
    #   then each value fully defines an aggregation instance.
    #   @return [Types::RateLimitQueryArgument]
    #
    # @!attribute [rw] query_string
    #   Use the request's query string as an aggregate key. Each distinct
    #   string contributes to the aggregation instance. If you use just the
    #   query string as your custom key, then each string fully defines an
    #   aggregation instance.
    #   @return [Types::RateLimitQueryString]
    #
    # @!attribute [rw] http_method
    #   Use the request's HTTP method as an aggregate key. Each distinct
    #   HTTP method contributes to the aggregation instance. If you use just
    #   the HTTP method as your custom key, then each method fully defines
    #   an aggregation instance.
    #   @return [Types::RateLimitHTTPMethod]
    #
    # @!attribute [rw] forwarded_ip
    #   Use the first IP address in an HTTP header as an aggregate key. Each
    #   distinct forwarded IP address contributes to the aggregation
    #   instance.
    #
    #   When you specify an IP or forwarded IP in the custom key settings,
    #   you must also specify at least one other key to use. You can
    #   aggregate on only the forwarded IP address by specifying
    #   `FORWARDED_IP` in your rate-based statement's `AggregateKeyType`.
    #
    #   With this option, you must specify the header to use in the
    #   rate-based rule's `ForwardedIPConfig` property.
    #   @return [Types::RateLimitForwardedIP]
    #
    # @!attribute [rw] ip
    #   Use the request's originating IP address as an aggregate key. Each
    #   distinct IP address contributes to the aggregation instance.
    #
    #   When you specify an IP or forwarded IP in the custom key settings,
    #   you must also specify at least one other key to use. You can
    #   aggregate on only the IP address by specifying `IP` in your
    #   rate-based statement's `AggregateKeyType`.
    #   @return [Types::RateLimitIP]
    #
    # @!attribute [rw] label_namespace
    #   Use the specified label namespace as an aggregate key. Each distinct
    #   fully qualified label name that has the specified label namespace
    #   contributes to the aggregation instance. If you use just one label
    #   namespace as your custom key, then each label name fully defines an
    #   aggregation instance.
    #
    #   This uses only labels that have been added to the request by rules
    #   that are evaluated before this rate-based rule in the web ACL.
    #
    #   For information about label namespaces and names, see [Label syntax
    #   and naming requirements][1] in the *WAF Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-rule-label-requirements.html
    #   @return [Types::RateLimitLabelNamespace]
    #
    # @!attribute [rw] uri_path
    #   Use the request's URI path as an aggregate key. Each distinct URI
    #   path contributes to the aggregation instance. If you use just the
    #   URI path as your custom key, then each URI path fully defines an
    #   aggregation instance.
    #   @return [Types::RateLimitUriPath]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RateBasedStatementCustomKey AWS API Documentation
    #
    class RateBasedStatementCustomKey < Struct.new(
      :header,
      :cookie,
      :query_argument,
      :query_string,
      :http_method,
      :forwarded_ip,
      :ip,
      :label_namespace,
      :uri_path)
      SENSITIVE = []
      include Aws::Structure
    end

    # The set of IP addresses that are currently blocked for a
    # RateBasedStatement. This is only available for rate-based rules that
    # aggregate on just the IP address, with the `AggregateKeyType` set to
    # `IP` or `FORWARDED_IP`.
    #
    # A rate-based rule applies its rule action to requests from IP
    # addresses that are in the rule's managed keys list and that match the
    # rule's scope-down statement. When a rule has no scope-down statement,
    # it applies the action to all requests from the IP addresses that are
    # in the list. The rule applies its rule action to rate limit the
    # matching requests. The action is usually Block but it can be any valid
    # rule action except for Allow.
    #
    # The maximum number of IP addresses that can be rate limited by a
    # single rate-based rule instance is 10,000. If more than 10,000
    # addresses exceed the rate limit, WAF limits those with the highest
    # rates.
    #
    # @!attribute [rw] ip_address_version
    #   The version of the IP addresses, either `IPV4` or `IPV6`.
    #   @return [String]
    #
    # @!attribute [rw] addresses
    #   The IP addresses that are currently blocked.
    #   @return [Array<String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RateBasedStatementManagedKeysIPSet AWS API Documentation
    #
    class RateBasedStatementManagedKeysIPSet < Struct.new(
      :ip_address_version,
      :addresses)
      SENSITIVE = []
      include Aws::Structure
    end

    # Specifies a cookie as an aggregate key for a rate-based rule. Each
    # distinct value in the cookie contributes to the aggregation instance.
    # If you use a single cookie as your custom key, then each value fully
    # defines an aggregation instance.
    #
    # @!attribute [rw] name
    #   The name of the cookie to use.
    #   @return [String]
    #
    # @!attribute [rw] text_transformations
    #   Text transformations eliminate some of the unusual formatting that
    #   attackers use in web requests in an effort to bypass detection. Text
    #   transformations are used in rule match statements, to transform the
    #   `FieldToMatch` request component before inspecting it, and they're
    #   used in rate-based rule statements, to transform request components
    #   before using them as custom aggregation keys. If you specify one or
    #   more transformations to apply, WAF performs all transformations on
    #   the specified content, starting from the lowest priority setting,
    #   and then uses the transformed component contents.
    #   @return [Array<Types::TextTransformation>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RateLimitCookie AWS API Documentation
    #
    class RateLimitCookie < Struct.new(
      :name,
      :text_transformations)
      SENSITIVE = []
      include Aws::Structure
    end

    # Specifies the first IP address in an HTTP header as an aggregate key
    # for a rate-based rule. Each distinct forwarded IP address contributes
    # to the aggregation instance.
    #
    # This setting is used only in the `RateBasedStatementCustomKey`
    # specification of a rate-based rule statement. When you specify an IP
    # or forwarded IP in the custom key settings, you must also specify at
    # least one other key to use. You can aggregate on only the forwarded IP
    # address by specifying `FORWARDED_IP` in your rate-based statement's
    # `AggregateKeyType`.
    #
    # This data type supports using the forwarded IP address in the web
    # request aggregation for a rate-based rule, in
    # `RateBasedStatementCustomKey`. The JSON specification for using the
    # forwarded IP address doesn't explicitly use this data type.
    #
    # JSON specification: `"ForwardedIP": {}`
    #
    # When you use this specification, you must also configure the forwarded
    # IP address in the rate-based statement's `ForwardedIPConfig`.
    #
    # @api private
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RateLimitForwardedIP AWS API Documentation
    #
    class RateLimitForwardedIP < Aws::EmptyStructure; end

    # Specifies the request's HTTP method as an aggregate key for a
    # rate-based rule. Each distinct HTTP method contributes to the
    # aggregation instance. If you use just the HTTP method as your custom
    # key, then each method fully defines an aggregation instance.
    #
    # JSON specification: `"RateLimitHTTPMethod": {}`
    #
    # @api private
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RateLimitHTTPMethod AWS API Documentation
    #
    class RateLimitHTTPMethod < Aws::EmptyStructure; end

    # Specifies a header as an aggregate key for a rate-based rule. Each
    # distinct value in the header contributes to the aggregation instance.
    # If you use a single header as your custom key, then each value fully
    # defines an aggregation instance.
    #
    # @!attribute [rw] name
    #   The name of the header to use.
    #   @return [String]
    #
    # @!attribute [rw] text_transformations
    #   Text transformations eliminate some of the unusual formatting that
    #   attackers use in web requests in an effort to bypass detection. Text
    #   transformations are used in rule match statements, to transform the
    #   `FieldToMatch` request component before inspecting it, and they're
    #   used in rate-based rule statements, to transform request components
    #   before using them as custom aggregation keys. If you specify one or
    #   more transformations to apply, WAF performs all transformations on
    #   the specified content, starting from the lowest priority setting,
    #   and then uses the transformed component contents.
    #   @return [Array<Types::TextTransformation>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RateLimitHeader AWS API Documentation
    #
    class RateLimitHeader < Struct.new(
      :name,
      :text_transformations)
      SENSITIVE = []
      include Aws::Structure
    end

    # Specifies the IP address in the web request as an aggregate key for a
    # rate-based rule. Each distinct IP address contributes to the
    # aggregation instance.
    #
    # This setting is used only in the `RateBasedStatementCustomKey`
    # specification of a rate-based rule statement. To use this in the
    # custom key settings, you must specify at least one other key to use,
    # along with the IP address. To aggregate on only the IP address, in
    # your rate-based statement's `AggregateKeyType`, specify `IP`.
    #
    # JSON specification: `"RateLimitIP": {}`
    #
    # @api private
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RateLimitIP AWS API Documentation
    #
    class RateLimitIP < Aws::EmptyStructure; end

    # Specifies a label namespace to use as an aggregate key for a
    # rate-based rule. Each distinct fully qualified label name that has the
    # specified label namespace contributes to the aggregation instance. If
    # you use just one label namespace as your custom key, then each label
    # name fully defines an aggregation instance.
    #
    # This uses only labels that have been added to the request by rules
    # that are evaluated before this rate-based rule in the web ACL.
    #
    # For information about label namespaces and names, see [Label syntax
    # and naming requirements][1] in the *WAF Developer Guide*.
    #
    #
    #
    # [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-rule-label-requirements.html
    #
    # @!attribute [rw] namespace
    #   The namespace to use for aggregation.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RateLimitLabelNamespace AWS API Documentation
    #
    class RateLimitLabelNamespace < Struct.new(
      :namespace)
      SENSITIVE = []
      include Aws::Structure
    end

    # Specifies a query argument in the request as an aggregate key for a
    # rate-based rule. Each distinct value for the named query argument
    # contributes to the aggregation instance. If you use a single query
    # argument as your custom key, then each value fully defines an
    # aggregation instance.
    #
    # @!attribute [rw] name
    #   The name of the query argument to use.
    #   @return [String]
    #
    # @!attribute [rw] text_transformations
    #   Text transformations eliminate some of the unusual formatting that
    #   attackers use in web requests in an effort to bypass detection. Text
    #   transformations are used in rule match statements, to transform the
    #   `FieldToMatch` request component before inspecting it, and they're
    #   used in rate-based rule statements, to transform request components
    #   before using them as custom aggregation keys. If you specify one or
    #   more transformations to apply, WAF performs all transformations on
    #   the specified content, starting from the lowest priority setting,
    #   and then uses the transformed component contents.
    #   @return [Array<Types::TextTransformation>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RateLimitQueryArgument AWS API Documentation
    #
    class RateLimitQueryArgument < Struct.new(
      :name,
      :text_transformations)
      SENSITIVE = []
      include Aws::Structure
    end

    # Specifies the request's query string as an aggregate key for a
    # rate-based rule. Each distinct string contributes to the aggregation
    # instance. If you use just the query string as your custom key, then
    # each string fully defines an aggregation instance.
    #
    # @!attribute [rw] text_transformations
    #   Text transformations eliminate some of the unusual formatting that
    #   attackers use in web requests in an effort to bypass detection. Text
    #   transformations are used in rule match statements, to transform the
    #   `FieldToMatch` request component before inspecting it, and they're
    #   used in rate-based rule statements, to transform request components
    #   before using them as custom aggregation keys. If you specify one or
    #   more transformations to apply, WAF performs all transformations on
    #   the specified content, starting from the lowest priority setting,
    #   and then uses the transformed component contents.
    #   @return [Array<Types::TextTransformation>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RateLimitQueryString AWS API Documentation
    #
    class RateLimitQueryString < Struct.new(
      :text_transformations)
      SENSITIVE = []
      include Aws::Structure
    end

    # Specifies the request's URI path as an aggregate key for a rate-based
    # rule. Each distinct URI path contributes to the aggregation instance.
    # If you use just the URI path as your custom key, then each URI path
    # fully defines an aggregation instance.
    #
    # @!attribute [rw] text_transformations
    #   Text transformations eliminate some of the unusual formatting that
    #   attackers use in web requests in an effort to bypass detection. Text
    #   transformations are used in rule match statements, to transform the
    #   `FieldToMatch` request component before inspecting it, and they're
    #   used in rate-based rule statements, to transform request components
    #   before using them as custom aggregation keys. If you specify one or
    #   more transformations to apply, WAF performs all transformations on
    #   the specified content, starting from the lowest priority setting,
    #   and then uses the transformed component contents.
    #   @return [Array<Types::TextTransformation>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RateLimitUriPath AWS API Documentation
    #
    class RateLimitUriPath < Struct.new(
      :text_transformations)
      SENSITIVE = []
      include Aws::Structure
    end

    # A single regular expression. This is used in a RegexPatternSet.
    #
    # @!attribute [rw] regex_string
    #   The string representing the regular expression.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/Regex AWS API Documentation
    #
    class Regex < Struct.new(
      :regex_string)
      SENSITIVE = []
      include Aws::Structure
    end

    # A rule statement used to search web request components for a match
    # against a single regular expression.
    #
    # @!attribute [rw] regex_string
    #   The string representing the regular expression.
    #   @return [String]
    #
    # @!attribute [rw] field_to_match
    #   The part of the web request that you want WAF to inspect.
    #   @return [Types::FieldToMatch]
    #
    # @!attribute [rw] text_transformations
    #   Text transformations eliminate some of the unusual formatting that
    #   attackers use in web requests in an effort to bypass detection. Text
    #   transformations are used in rule match statements, to transform the
    #   `FieldToMatch` request component before inspecting it, and they're
    #   used in rate-based rule statements, to transform request components
    #   before using them as custom aggregation keys. If you specify one or
    #   more transformations to apply, WAF performs all transformations on
    #   the specified content, starting from the lowest priority setting,
    #   and then uses the transformed component contents.
    #   @return [Array<Types::TextTransformation>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RegexMatchStatement AWS API Documentation
    #
    class RegexMatchStatement < Struct.new(
      :regex_string,
      :field_to_match,
      :text_transformations)
      SENSITIVE = []
      include Aws::Structure
    end

    # Contains one or more regular expressions.
    #
    # WAF assigns an ARN to each `RegexPatternSet` that you create. To use a
    # set in a rule, you provide the ARN to the Rule statement
    # RegexPatternSetReferenceStatement.
    #
    # @!attribute [rw] name
    #   The name of the set. You cannot change the name after you create the
    #   set.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the set. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the entity.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   A description of the set that helps with identification.
    #   @return [String]
    #
    # @!attribute [rw] regular_expression_list
    #   The regular expression patterns in the set.
    #   @return [Array<Types::Regex>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RegexPatternSet AWS API Documentation
    #
    class RegexPatternSet < Struct.new(
      :name,
      :id,
      :arn,
      :description,
      :regular_expression_list)
      SENSITIVE = []
      include Aws::Structure
    end

    # 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. To create a regex pattern set, see CreateRegexPatternSet.
    #
    # 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, WAF automatically updates all rules that reference it.
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the RegexPatternSet that this
    #   statement references.
    #   @return [String]
    #
    # @!attribute [rw] field_to_match
    #   The part of the web request that you want WAF to inspect.
    #   @return [Types::FieldToMatch]
    #
    # @!attribute [rw] text_transformations
    #   Text transformations eliminate some of the unusual formatting that
    #   attackers use in web requests in an effort to bypass detection. Text
    #   transformations are used in rule match statements, to transform the
    #   `FieldToMatch` request component before inspecting it, and they're
    #   used in rate-based rule statements, to transform request components
    #   before using them as custom aggregation keys. If you specify one or
    #   more transformations to apply, WAF performs all transformations on
    #   the specified content, starting from the lowest priority setting,
    #   and then uses the transformed component contents.
    #   @return [Array<Types::TextTransformation>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RegexPatternSetReferenceStatement AWS API Documentation
    #
    class RegexPatternSetReferenceStatement < Struct.new(
      :arn,
      :field_to_match,
      :text_transformations)
      SENSITIVE = []
      include Aws::Structure
    end

    # High-level information about a RegexPatternSet, returned by operations
    # like create and list. This provides information like the ID, that you
    # can use to retrieve and manage a `RegexPatternSet`, and the ARN, that
    # you provide to the RegexPatternSetReferenceStatement to use the
    # pattern set in a Rule.
    #
    # @!attribute [rw] name
    #   The name of the data type instance. You cannot change the name after
    #   you create the instance.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the set. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   A description of the set that helps with identification.
    #   @return [String]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the entity.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RegexPatternSetSummary AWS API Documentation
    #
    class RegexPatternSetSummary < Struct.new(
      :name,
      :id,
      :description,
      :lock_token,
      :arn)
      SENSITIVE = []
      include Aws::Structure
    end

    # High level information for an SDK release.
    #
    # @!attribute [rw] release_version
    #   The release version.
    #   @return [String]
    #
    # @!attribute [rw] timestamp
    #   The timestamp of the release.
    #   @return [Time]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ReleaseSummary AWS API Documentation
    #
    class ReleaseSummary < Struct.new(
      :release_version,
      :timestamp)
      SENSITIVE = []
      include Aws::Structure
    end

    # Customizes the maximum size of the request body that your protected
    # CloudFront, API Gateway, Amazon Cognito, App Runner, and Verified
    # Access resources forward to WAF for inspection. The default size is 16
    # KB (16,384 bytes). You can change the setting for any of the available
    # resource types.
    #
    # <note markdown="1"> You are charged additional fees when your protected resources forward
    # body sizes that are larger than the default. For more information, see
    # [WAF Pricing][1].
    #
    #  </note>
    #
    # Example JSON: ` { "API_GATEWAY": "KB_48", "APP_RUNNER_SERVICE":
    # "KB_32" }`
    #
    # For Application Load Balancer and AppSync, the limit is fixed at 8 KB
    # (8,192 bytes).
    #
    # This is used in the `AssociationConfig` of the web ACL.
    #
    #
    #
    # [1]: http://aws.amazon.com/waf/pricing/
    #
    # @!attribute [rw] default_size_inspection_limit
    #   Specifies the maximum size of the web request body component that an
    #   associated CloudFront, API Gateway, Amazon Cognito, App Runner, or
    #   Verified Access resource should send to WAF for inspection. This
    #   applies to statements in the web ACL that inspect the body or JSON
    #   body.
    #
    #   Default: `16 KB (16,384 bytes)`
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RequestBodyAssociatedResourceTypeConfig AWS API Documentation
    #
    class RequestBodyAssociatedResourceTypeConfig < Struct.new(
      :default_size_inspection_limit)
      SENSITIVE = []
      include Aws::Structure
    end

    # The criteria for inspecting login requests, used by the ATP rule group
    # to validate credentials usage.
    #
    # This is part of the `AWSManagedRulesATPRuleSet` configuration in
    # `ManagedRuleGroupConfig`.
    #
    # In these settings, you specify how your application accepts login
    # attempts by providing the request payload type and the names of the
    # fields within the request body where the username and password are
    # provided.
    #
    # @!attribute [rw] payload_type
    #   The payload type for your login endpoint, either JSON or form
    #   encoded.
    #   @return [String]
    #
    # @!attribute [rw] username_field
    #   The name of the field in the request payload that contains your
    #   customer's username.
    #
    #   How you specify this depends on the request inspection payload type.
    #
    #   * For JSON payloads, specify the field name in JSON pointer syntax.
    #     For information about the JSON Pointer syntax, see the Internet
    #     Engineering Task Force (IETF) documentation [JavaScript Object
    #     Notation (JSON) Pointer][1].
    #
    #     For example, for the JSON payload `{ "form": { "username":
    #     "THE_USERNAME" } }`, the username field specification is
    #     `/form/username`.
    #
    #   * For form encoded payload types, use the HTML form names.
    #
    #     For example, for an HTML form with the input element named
    #     `username1`, the username field specification is `username1`
    #
    #
    #
    #   [1]: https://tools.ietf.org/html/rfc6901
    #   @return [Types::UsernameField]
    #
    # @!attribute [rw] password_field
    #   The name of the field in the request payload that contains your
    #   customer's password.
    #
    #   How you specify this depends on the request inspection payload type.
    #
    #   * For JSON payloads, specify the field name in JSON pointer syntax.
    #     For information about the JSON Pointer syntax, see the Internet
    #     Engineering Task Force (IETF) documentation [JavaScript Object
    #     Notation (JSON) Pointer][1].
    #
    #     For example, for the JSON payload `{ "form": { "password":
    #     "THE_PASSWORD" } }`, the password field specification is
    #     `/form/password`.
    #
    #   * For form encoded payload types, use the HTML form names.
    #
    #     For example, for an HTML form with the input element named
    #     `password1`, the password field specification is `password1`.
    #
    #
    #
    #   [1]: https://tools.ietf.org/html/rfc6901
    #   @return [Types::PasswordField]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RequestInspection AWS API Documentation
    #
    class RequestInspection < Struct.new(
      :payload_type,
      :username_field,
      :password_field)
      SENSITIVE = []
      include Aws::Structure
    end

    # The criteria for inspecting account creation requests, used by the
    # ACFP rule group to validate and track account creation attempts.
    #
    # This is part of the `AWSManagedRulesACFPRuleSet` configuration in
    # `ManagedRuleGroupConfig`.
    #
    # In these settings, you specify how your application accepts account
    # creation attempts by providing the request payload type and the names
    # of the fields within the request body where the username, password,
    # email, and primary address and phone number fields are provided.
    #
    # @!attribute [rw] payload_type
    #   The payload type for your account creation endpoint, either JSON or
    #   form encoded.
    #   @return [String]
    #
    # @!attribute [rw] username_field
    #   The name of the field in the request payload that contains your
    #   customer's username.
    #
    #   How you specify this depends on the request inspection payload type.
    #
    #   * For JSON payloads, specify the field name in JSON pointer syntax.
    #     For information about the JSON Pointer syntax, see the Internet
    #     Engineering Task Force (IETF) documentation [JavaScript Object
    #     Notation (JSON) Pointer][1].
    #
    #     For example, for the JSON payload `{ "form": { "username":
    #     "THE_USERNAME" } }`, the username field specification is
    #     `/form/username`.
    #
    #   * For form encoded payload types, use the HTML form names.
    #
    #     For example, for an HTML form with the input element named
    #     `username1`, the username field specification is `username1`
    #
    #
    #
    #   [1]: https://tools.ietf.org/html/rfc6901
    #   @return [Types::UsernameField]
    #
    # @!attribute [rw] password_field
    #   The name of the field in the request payload that contains your
    #   customer's password.
    #
    #   How you specify this depends on the request inspection payload type.
    #
    #   * For JSON payloads, specify the field name in JSON pointer syntax.
    #     For information about the JSON Pointer syntax, see the Internet
    #     Engineering Task Force (IETF) documentation [JavaScript Object
    #     Notation (JSON) Pointer][1].
    #
    #     For example, for the JSON payload `{ "form": { "password":
    #     "THE_PASSWORD" } }`, the password field specification is
    #     `/form/password`.
    #
    #   * For form encoded payload types, use the HTML form names.
    #
    #     For example, for an HTML form with the input element named
    #     `password1`, the password field specification is `password1`.
    #
    #
    #
    #   [1]: https://tools.ietf.org/html/rfc6901
    #   @return [Types::PasswordField]
    #
    # @!attribute [rw] email_field
    #   The name of the field in the request payload that contains your
    #   customer's email.
    #
    #   How you specify this depends on the request inspection payload type.
    #
    #   * For JSON payloads, specify the field name in JSON pointer syntax.
    #     For information about the JSON Pointer syntax, see the Internet
    #     Engineering Task Force (IETF) documentation [JavaScript Object
    #     Notation (JSON) Pointer][1].
    #
    #     For example, for the JSON payload `{ "form": { "email":
    #     "THE_EMAIL" } }`, the email field specification is `/form/email`.
    #
    #   * For form encoded payload types, use the HTML form names.
    #
    #     For example, for an HTML form with the input element named
    #     `email1`, the email field specification is `email1`.
    #
    #
    #
    #   [1]: https://tools.ietf.org/html/rfc6901
    #   @return [Types::EmailField]
    #
    # @!attribute [rw] phone_number_fields
    #   The names of the fields in the request payload that contain your
    #   customer's primary phone number.
    #
    #   Order the phone number fields in the array exactly as they are
    #   ordered in the request payload.
    #
    #   How you specify the phone number fields depends on the request
    #   inspection payload type.
    #
    #   * For JSON payloads, specify the field identifiers in JSON pointer
    #     syntax. For information about the JSON Pointer syntax, see the
    #     Internet Engineering Task Force (IETF) documentation [JavaScript
    #     Object Notation (JSON) Pointer][1].
    #
    #     For example, for the JSON payload `{ "form": {
    #     "primaryphoneline1": "THE_PHONE1", "primaryphoneline2":
    #     "THE_PHONE2", "primaryphoneline3": "THE_PHONE3" } }`, the phone
    #     number field identifiers are `/form/primaryphoneline1`,
    #     `/form/primaryphoneline2`, and `/form/primaryphoneline3`.
    #
    #   * For form encoded payload types, use the HTML form names.
    #
    #     For example, for an HTML form with input elements named
    #     `primaryphoneline1`, `primaryphoneline2`, and `primaryphoneline3`,
    #     the phone number field identifiers are `primaryphoneline1`,
    #     `primaryphoneline2`, and `primaryphoneline3`.
    #
    #
    #
    #   [1]: https://tools.ietf.org/html/rfc6901
    #   @return [Array<Types::PhoneNumberField>]
    #
    # @!attribute [rw] address_fields
    #   The names of the fields in the request payload that contain your
    #   customer's primary physical address.
    #
    #   Order the address fields in the array exactly as they are ordered in
    #   the request payload.
    #
    #   How you specify the address fields depends on the request inspection
    #   payload type.
    #
    #   * For JSON payloads, specify the field identifiers in JSON pointer
    #     syntax. For information about the JSON Pointer syntax, see the
    #     Internet Engineering Task Force (IETF) documentation [JavaScript
    #     Object Notation (JSON) Pointer][1].
    #
    #     For example, for the JSON payload `{ "form": {
    #     "primaryaddressline1": "THE_ADDRESS1", "primaryaddressline2":
    #     "THE_ADDRESS2", "primaryaddressline3": "THE_ADDRESS3" } }`, the
    #     address field idenfiers are `/form/primaryaddressline1`,
    #     `/form/primaryaddressline2`, and `/form/primaryaddressline3`.
    #
    #   * For form encoded payload types, use the HTML form names.
    #
    #     For example, for an HTML form with input elements named
    #     `primaryaddressline1`, `primaryaddressline2`, and
    #     `primaryaddressline3`, the address fields identifiers are
    #     `primaryaddressline1`, `primaryaddressline2`, and
    #     `primaryaddressline3`.
    #
    #
    #
    #   [1]: https://tools.ietf.org/html/rfc6901
    #   @return [Array<Types::AddressField>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RequestInspectionACFP AWS API Documentation
    #
    class RequestInspectionACFP < Struct.new(
      :payload_type,
      :username_field,
      :password_field,
      :email_field,
      :phone_number_fields,
      :address_fields)
      SENSITIVE = []
      include Aws::Structure
    end

    # The criteria for inspecting responses to login requests and account
    # creation requests, used by the ATP and ACFP rule groups to track login
    # and account creation success and failure rates.
    #
    # <note markdown="1"> Response inspection is available only in web ACLs that protect Amazon
    # CloudFront distributions.
    #
    #  </note>
    #
    # The rule groups evaluates the responses that your protected resources
    # send back to client login and account creation attempts, keeping count
    # of successful and failed attempts from each IP address and client
    # session. Using this information, the rule group labels and mitigates
    # requests from client sessions and IP addresses with too much
    # suspicious activity in a short amount of time.
    #
    # This is part of the `AWSManagedRulesATPRuleSet` and
    # `AWSManagedRulesACFPRuleSet` configurations in
    # `ManagedRuleGroupConfig`.
    #
    # Enable response inspection by configuring exactly one component of the
    # response to inspect, for example, `Header` or `StatusCode`. You can't
    # configure more than one component for inspection. If you don't
    # configure any of the response inspection options, response inspection
    # is disabled.
    #
    # @!attribute [rw] status_code
    #   Configures inspection of the response status code for success and
    #   failure indicators.
    #   @return [Types::ResponseInspectionStatusCode]
    #
    # @!attribute [rw] header
    #   Configures inspection of the response header for success and failure
    #   indicators.
    #   @return [Types::ResponseInspectionHeader]
    #
    # @!attribute [rw] body_contains
    #   Configures inspection of the response body for success and failure
    #   indicators. WAF can inspect the first 65,536 bytes (64 KB) of the
    #   response body.
    #   @return [Types::ResponseInspectionBodyContains]
    #
    # @!attribute [rw] json
    #   Configures inspection of the response JSON for success and failure
    #   indicators. WAF can inspect the first 65,536 bytes (64 KB) of the
    #   response JSON.
    #   @return [Types::ResponseInspectionJson]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ResponseInspection AWS API Documentation
    #
    class ResponseInspection < Struct.new(
      :status_code,
      :header,
      :body_contains,
      :json)
      SENSITIVE = []
      include Aws::Structure
    end

    # Configures inspection of the response body. WAF can inspect the first
    # 65,536 bytes (64 KB) of the response body. This is part of the
    # `ResponseInspection` configuration for `AWSManagedRulesATPRuleSet` and
    # `AWSManagedRulesACFPRuleSet`.
    #
    # <note markdown="1"> Response inspection is available only in web ACLs that protect Amazon
    # CloudFront distributions.
    #
    #  </note>
    #
    # @!attribute [rw] success_strings
    #   Strings in the body of the response that indicate a successful login
    #   or account creation attempt. To be counted as a success, the string
    #   can be anywhere in the body and must be an exact match, including
    #   case. Each string must be unique among the success and failure
    #   strings.
    #
    #   JSON examples: `"SuccessStrings": [ "Login successful" ]` and
    #   `"SuccessStrings": [ "Account creation successful", "Welcome to our
    #   site!" ]`
    #   @return [Array<String>]
    #
    # @!attribute [rw] failure_strings
    #   Strings in the body of the response that indicate a failed login or
    #   account creation attempt. To be counted as a failure, the string can
    #   be anywhere in the body and must be an exact match, including case.
    #   Each string must be unique among the success and failure strings.
    #
    #   JSON example: `"FailureStrings": [ "Request failed" ]`
    #   @return [Array<String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ResponseInspectionBodyContains AWS API Documentation
    #
    class ResponseInspectionBodyContains < Struct.new(
      :success_strings,
      :failure_strings)
      SENSITIVE = []
      include Aws::Structure
    end

    # Configures inspection of the response header. This is part of the
    # `ResponseInspection` configuration for `AWSManagedRulesATPRuleSet` and
    # `AWSManagedRulesACFPRuleSet`.
    #
    # <note markdown="1"> Response inspection is available only in web ACLs that protect Amazon
    # CloudFront distributions.
    #
    #  </note>
    #
    # @!attribute [rw] name
    #   The name of the header to match against. The name must be an exact
    #   match, including case.
    #
    #   JSON example: `"Name": [ "RequestResult" ]`
    #   @return [String]
    #
    # @!attribute [rw] success_values
    #   Values in the response header with the specified name that indicate
    #   a successful login or account creation attempt. To be counted as a
    #   success, the value must be an exact match, including case. Each
    #   value must be unique among the success and failure values.
    #
    #   JSON examples: `"SuccessValues": [ "LoginPassed", "Successful login"
    #   ]` and `"SuccessValues": [ "AccountCreated", "Successful account
    #   creation" ]`
    #   @return [Array<String>]
    #
    # @!attribute [rw] failure_values
    #   Values in the response header with the specified name that indicate
    #   a failed login or account creation attempt. To be counted as a
    #   failure, the value must be an exact match, including case. Each
    #   value must be unique among the success and failure values.
    #
    #   JSON examples: `"FailureValues": [ "LoginFailed", "Failed login" ]`
    #   and `"FailureValues": [ "AccountCreationFailed" ]`
    #   @return [Array<String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ResponseInspectionHeader AWS API Documentation
    #
    class ResponseInspectionHeader < Struct.new(
      :name,
      :success_values,
      :failure_values)
      SENSITIVE = []
      include Aws::Structure
    end

    # Configures inspection of the response JSON. WAF can inspect the first
    # 65,536 bytes (64 KB) of the response JSON. This is part of the
    # `ResponseInspection` configuration for `AWSManagedRulesATPRuleSet` and
    # `AWSManagedRulesACFPRuleSet`.
    #
    # <note markdown="1"> Response inspection is available only in web ACLs that protect Amazon
    # CloudFront distributions.
    #
    #  </note>
    #
    # @!attribute [rw] identifier
    #   The identifier for the value to match against in the JSON. The
    #   identifier must be an exact match, including case.
    #
    #   JSON examples: `"Identifier": [ "/login/success" ]` and
    #   `"Identifier": [ "/sign-up/success" ]`
    #   @return [String]
    #
    # @!attribute [rw] success_values
    #   Values for the specified identifier in the response JSON that
    #   indicate a successful login or account creation attempt. To be
    #   counted as a success, the value must be an exact match, including
    #   case. Each value must be unique among the success and failure
    #   values.
    #
    #   JSON example: `"SuccessValues": [ "True", "Succeeded" ]`
    #   @return [Array<String>]
    #
    # @!attribute [rw] failure_values
    #   Values for the specified identifier in the response JSON that
    #   indicate a failed login or account creation attempt. To be counted
    #   as a failure, the value must be an exact match, including case. Each
    #   value must be unique among the success and failure values.
    #
    #   JSON example: `"FailureValues": [ "False", "Failed" ]`
    #   @return [Array<String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ResponseInspectionJson AWS API Documentation
    #
    class ResponseInspectionJson < Struct.new(
      :identifier,
      :success_values,
      :failure_values)
      SENSITIVE = []
      include Aws::Structure
    end

    # Configures inspection of the response status code. This is part of the
    # `ResponseInspection` configuration for `AWSManagedRulesATPRuleSet` and
    # `AWSManagedRulesACFPRuleSet`.
    #
    # <note markdown="1"> Response inspection is available only in web ACLs that protect Amazon
    # CloudFront distributions.
    #
    #  </note>
    #
    # @!attribute [rw] success_codes
    #   Status codes in the response that indicate a successful login or
    #   account creation attempt. To be counted as a success, the response
    #   status code must match one of these. Each code must be unique among
    #   the success and failure status codes.
    #
    #   JSON example: `"SuccessCodes": [ 200, 201 ]`
    #   @return [Array<Integer>]
    #
    # @!attribute [rw] failure_codes
    #   Status codes in the response that indicate a failed login or account
    #   creation attempt. To be counted as a failure, the response status
    #   code must match one of these. Each code must be unique among the
    #   success and failure status codes.
    #
    #   JSON example: `"FailureCodes": [ 400, 404 ]`
    #   @return [Array<Integer>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/ResponseInspectionStatusCode AWS API Documentation
    #
    class ResponseInspectionStatusCode < Struct.new(
      :success_codes,
      :failure_codes)
      SENSITIVE = []
      include Aws::Structure
    end

    # A single rule, which you can use in a WebACL or RuleGroup to identify
    # web requests that you want to manage in some way. Each rule includes
    # one top-level Statement that WAF uses to identify matching web
    # requests, and parameters that govern how WAF handles them.
    #
    # @!attribute [rw] name
    #   The name of the rule.
    #
    #   If you change the name of a `Rule` after you create it and you want
    #   the rule's metric name to reflect the change, update the metric
    #   name in the rule's `VisibilityConfig` settings. WAF doesn't
    #   automatically update the metric name when you update the rule name.
    #   @return [String]
    #
    # @!attribute [rw] priority
    #   If you define more than one `Rule` in a `WebACL`, WAF evaluates each
    #   request against the `Rules` in order based on the value of
    #   `Priority`. WAF processes rules with lower priority first. The
    #   priorities don't need to be consecutive, but they must all be
    #   different.
    #   @return [Integer]
    #
    # @!attribute [rw] statement
    #   The WAF processing statement for the rule, for example
    #   ByteMatchStatement or SizeConstraintStatement.
    #   @return [Types::Statement]
    #
    # @!attribute [rw] action
    #   The action that WAF should take on a web request when it matches the
    #   rule statement. Settings at the web ACL level can override the rule
    #   action setting.
    #
    #   This is used only for rules whose statements do not reference a rule
    #   group. Rule statements that reference a rule group include
    #   `RuleGroupReferenceStatement` and `ManagedRuleGroupStatement`.
    #
    #   You must specify either this `Action` setting or the rule
    #   `OverrideAction` setting, but not both:
    #
    #   * If the rule statement does not reference a rule group, use this
    #     rule action setting and not the rule override action setting.
    #
    #   * If the rule statement references a rule group, use the override
    #     action setting and not this action setting.
    #   @return [Types::RuleAction]
    #
    # @!attribute [rw] override_action
    #   The action to use in the place of the action that results from the
    #   rule group evaluation. Set the override action to none to leave the
    #   result of the rule group alone. Set it to count to override the
    #   result to count only.
    #
    #   You can only use this for rule statements that reference a rule
    #   group, like `RuleGroupReferenceStatement` and
    #   `ManagedRuleGroupStatement`.
    #
    #   <note markdown="1"> This option is usually set to none. It does not affect how the rules
    #   in the rule group are evaluated. If you want the rules in the rule
    #   group to only count matches, do not use this and instead use the
    #   rule action override option, with `Count` action, in your rule group
    #   reference statement settings.
    #
    #    </note>
    #   @return [Types::OverrideAction]
    #
    # @!attribute [rw] rule_labels
    #   Labels to apply to web requests that match the rule match statement.
    #   WAF applies fully qualified labels to matching web requests. A fully
    #   qualified label is the concatenation of a label namespace and a rule
    #   label. The rule's rule group or web ACL defines the label
    #   namespace.
    #
    #   Rules that run after this rule in the web ACL can match against
    #   these labels using a `LabelMatchStatement`.
    #
    #   For each label, provide a case-sensitive string containing optional
    #   namespaces and a label name, according to the following guidelines:
    #
    #   * Separate each component of the label with a colon.
    #
    #   * Each namespace or name can have up to 128 characters.
    #
    #   * You can specify up to 5 namespaces in a label.
    #
    #   * Don't use the following reserved words in your label
    #     specification: `aws`, `waf`, `managed`, `rulegroup`, `webacl`,
    #     `regexpatternset`, or `ipset`.
    #
    #   For example, `myLabelName` or `nameSpace1:nameSpace2:myLabelName`.
    #   @return [Array<Types::Label>]
    #
    # @!attribute [rw] visibility_config
    #   Defines and enables Amazon CloudWatch metrics and web request sample
    #   collection.
    #
    #   If you change the name of a `Rule` after you create it and you want
    #   the rule's metric name to reflect the change, update the metric
    #   name as well. WAF doesn't automatically update the metric name.
    #   @return [Types::VisibilityConfig]
    #
    # @!attribute [rw] captcha_config
    #   Specifies how WAF should handle `CAPTCHA` evaluations. If you don't
    #   specify this, WAF uses the `CAPTCHA` configuration that's defined
    #   for the web ACL.
    #   @return [Types::CaptchaConfig]
    #
    # @!attribute [rw] challenge_config
    #   Specifies how WAF should handle `Challenge` evaluations. If you
    #   don't specify this, WAF uses the challenge configuration that's
    #   defined for the web ACL.
    #   @return [Types::ChallengeConfig]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/Rule AWS API Documentation
    #
    class Rule < Struct.new(
      :name,
      :priority,
      :statement,
      :action,
      :override_action,
      :rule_labels,
      :visibility_config,
      :captcha_config,
      :challenge_config)
      SENSITIVE = []
      include Aws::Structure
    end

    # The action that WAF should take on a web request when it matches a
    # rule's statement. Settings at the web ACL level can override the rule
    # action setting.
    #
    # @!attribute [rw] block
    #   Instructs WAF to block the web request.
    #   @return [Types::BlockAction]
    #
    # @!attribute [rw] allow
    #   Instructs WAF to allow the web request.
    #   @return [Types::AllowAction]
    #
    # @!attribute [rw] count
    #   Instructs WAF to count the web request and then continue evaluating
    #   the request using the remaining rules in the web ACL.
    #   @return [Types::CountAction]
    #
    # @!attribute [rw] captcha
    #   Instructs WAF to run a `CAPTCHA` check against the web request.
    #   @return [Types::CaptchaAction]
    #
    # @!attribute [rw] challenge
    #   Instructs WAF to run a `Challenge` check against the web request.
    #   @return [Types::ChallengeAction]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RuleAction AWS API Documentation
    #
    class RuleAction < Struct.new(
      :block,
      :allow,
      :count,
      :captcha,
      :challenge)
      SENSITIVE = []
      include Aws::Structure
    end

    # Action setting to use in the place of a rule action that is configured
    # inside the rule group. You specify one override for each rule whose
    # action you want to change.
    #
    # You can use overrides for testing, for example you can override all of
    # rule actions to `Count` and then monitor the resulting count metrics
    # to understand how the rule group would handle your web traffic. You
    # can also permanently override some or all actions, to modify how the
    # rule group manages your web traffic.
    #
    # @!attribute [rw] name
    #   The name of the rule to override.
    #   @return [String]
    #
    # @!attribute [rw] action_to_use
    #   The override action to use, in place of the configured action of the
    #   rule in the rule group.
    #   @return [Types::RuleAction]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RuleActionOverride AWS API Documentation
    #
    class RuleActionOverride < Struct.new(
      :name,
      :action_to_use)
      SENSITIVE = []
      include Aws::Structure
    end

    # A rule group defines a collection of rules to inspect and control web
    # requests that you can use in a WebACL. When you create a rule group,
    # you define an immutable capacity limit. If you update a rule group,
    # you must stay within the capacity. This allows others to reuse the
    # rule group with confidence in its capacity requirements.
    #
    # @!attribute [rw] name
    #   The name of the rule group. You cannot change the name of a rule
    #   group after you create it.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the rule group. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @!attribute [rw] capacity
    #   The web ACL capacity units (WCUs) required for this rule group.
    #
    #   When you create your own rule group, you define this, and you cannot
    #   change it after creation. When you add or modify the rules in a rule
    #   group, WAF enforces this limit. You can check the capacity for a set
    #   of rules using CheckCapacity.
    #
    #   WAF uses WCUs to calculate and control the operating resources that
    #   are used to run your rules, rule groups, and web ACLs. WAF
    #   calculates capacity differently for each rule type, to reflect the
    #   relative cost of each rule. Simple rules that cost little to run use
    #   fewer WCUs than more complex rules that use more processing power.
    #   Rule group capacity is fixed at creation, which helps users plan
    #   their web ACL WCU usage when they use a rule group. For more
    #   information, see [WAF web ACL capacity units (WCU)][1] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/aws-waf-capacity-units.html
    #   @return [Integer]
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the entity.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   A description of the rule group that helps with identification.
    #   @return [String]
    #
    # @!attribute [rw] rules
    #   The Rule statements used to identify the web requests that you want
    #   to manage. Each rule includes one top-level statement that WAF uses
    #   to identify matching web requests, and parameters that govern how
    #   WAF handles them.
    #   @return [Array<Types::Rule>]
    #
    # @!attribute [rw] visibility_config
    #   Defines and enables Amazon CloudWatch metrics and web request sample
    #   collection.
    #   @return [Types::VisibilityConfig]
    #
    # @!attribute [rw] label_namespace
    #   The label namespace prefix for this rule group. All labels added by
    #   rules in this rule group have this prefix.
    #
    #   * The syntax for the label namespace prefix for your rule groups is
    #     the following:
    #
    #     `awswaf:<account ID>:rulegroup:<rule group name>:`
    #
    #   * When a rule with a label matches a web request, WAF adds the fully
    #     qualified label to the request. A fully qualified label is made up
    #     of the label namespace from the rule group or web ACL where the
    #     rule is defined and the label from the rule, separated by a colon:
    #
    #     `<label namespace>:<label from rule>`
    #   @return [String]
    #
    # @!attribute [rw] custom_response_bodies
    #   A map of custom response keys and content bodies. When you create a
    #   rule with a block action, you can send a custom response to the web
    #   request. You define these for the rule group, and then use them in
    #   the rules that you define in the rule group.
    #
    #   For information about customizing web requests and responses, see
    #   [Customizing web requests and responses in WAF][1] in the *WAF
    #   Developer Guide*.
    #
    #   For information about the limits on count and size for custom
    #   request and response settings, see [WAF quotas][2] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html
    #   [2]: https://docs.aws.amazon.com/waf/latest/developerguide/limits.html
    #   @return [Hash<String,Types::CustomResponseBody>]
    #
    # @!attribute [rw] available_labels
    #   The labels that one or more rules in this rule group add to matching
    #   web requests. These labels are defined in the `RuleLabels` for a
    #   Rule.
    #   @return [Array<Types::LabelSummary>]
    #
    # @!attribute [rw] consumed_labels
    #   The labels that one or more rules in this rule group match against
    #   in label match statements. These labels are defined in a
    #   `LabelMatchStatement` specification, in the Statement definition of
    #   a rule.
    #   @return [Array<Types::LabelSummary>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RuleGroup AWS API Documentation
    #
    class RuleGroup < Struct.new(
      :name,
      :id,
      :capacity,
      :arn,
      :description,
      :rules,
      :visibility_config,
      :label_namespace,
      :custom_response_bodies,
      :available_labels,
      :consumed_labels)
      SENSITIVE = []
      include Aws::Structure
    end

    # A rule statement used to run the rules that are defined in a
    # RuleGroup. 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.
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the entity.
    #   @return [String]
    #
    # @!attribute [rw] excluded_rules
    #   Rules in the referenced rule group whose actions are set to `Count`.
    #
    #   <note markdown="1"> Instead of this option, use `RuleActionOverrides`. It accepts any
    #   valid action setting, including `Count`.
    #
    #    </note>
    #   @return [Array<Types::ExcludedRule>]
    #
    # @!attribute [rw] rule_action_overrides
    #   Action settings to use in the place of the rule actions that are
    #   configured inside the rule group. You specify one override for each
    #   rule whose action you want to change.
    #
    #   You can use overrides for testing, for example you can override all
    #   of rule actions to `Count` and then monitor the resulting count
    #   metrics to understand how the rule group would handle your web
    #   traffic. You can also permanently override some or all actions, to
    #   modify how the rule group manages your web traffic.
    #   @return [Array<Types::RuleActionOverride>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RuleGroupReferenceStatement AWS API Documentation
    #
    class RuleGroupReferenceStatement < Struct.new(
      :arn,
      :excluded_rules,
      :rule_action_overrides)
      SENSITIVE = []
      include Aws::Structure
    end

    # High-level information about a RuleGroup, returned by operations like
    # create and list. This provides information like the ID, that you can
    # use to retrieve and manage a `RuleGroup`, and the ARN, that you
    # provide to the RuleGroupReferenceStatement to use the rule group in a
    # Rule.
    #
    # @!attribute [rw] name
    #   The name of the data type instance. You cannot change the name after
    #   you create the instance.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the rule group. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   A description of the rule group that helps with identification.
    #   @return [String]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the entity.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RuleGroupSummary AWS API Documentation
    #
    class RuleGroupSummary < Struct.new(
      :name,
      :id,
      :description,
      :lock_token,
      :arn)
      SENSITIVE = []
      include Aws::Structure
    end

    # High-level information about a Rule, returned by operations like
    # DescribeManagedRuleGroup. This provides information like the ID, that
    # you can use to retrieve and manage a `RuleGroup`, and the ARN, that
    # you provide to the RuleGroupReferenceStatement to use the rule group
    # in a Rule.
    #
    # @!attribute [rw] name
    #   The name of the rule.
    #   @return [String]
    #
    # @!attribute [rw] action
    #   The action that WAF should take on a web request when it matches a
    #   rule's statement. Settings at the web ACL level can override the
    #   rule action setting.
    #   @return [Types::RuleAction]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/RuleSummary AWS API Documentation
    #
    class RuleSummary < Struct.new(
      :name,
      :action)
      SENSITIVE = []
      include Aws::Structure
    end

    # Represents a single sampled web request. The response from
    # GetSampledRequests includes a `SampledHTTPRequests` complex type that
    # appears as `SampledRequests` in the response syntax.
    # `SampledHTTPRequests` contains an array of `SampledHTTPRequest`
    # objects.
    #
    # @!attribute [rw] request
    #   A complex type that contains detailed information about the request.
    #   @return [Types::HTTPRequest]
    #
    # @!attribute [rw] weight
    #   A value that indicates how one result in the response relates
    #   proportionally to other results in the response. For example, a
    #   result that has a weight of `2` represents roughly twice as many web
    #   requests as a result that has a weight of `1`.
    #   @return [Integer]
    #
    # @!attribute [rw] timestamp
    #   The time at which WAF received the request from your Amazon Web
    #   Services resource, in Unix time format (in seconds).
    #   @return [Time]
    #
    # @!attribute [rw] action
    #   The action that WAF applied to the request.
    #   @return [String]
    #
    # @!attribute [rw] rule_name_within_rule_group
    #   The name of the `Rule` that the request matched. For managed rule
    #   groups, the format for this name is `<vendor name>#<managed rule
    #   group name>#<rule name>`. For your own rule groups, the format for
    #   this name is `<rule group name>#<rule name>`. If the rule is not in
    #   a rule group, this field is absent.
    #   @return [String]
    #
    # @!attribute [rw] request_headers_inserted
    #   Custom request headers inserted by WAF into the request, according
    #   to the custom request configuration for the matching rule action.
    #   @return [Array<Types::HTTPHeader>]
    #
    # @!attribute [rw] response_code_sent
    #   The response code that was sent for the request.
    #   @return [Integer]
    #
    # @!attribute [rw] labels
    #   Labels applied to the web request by matching rules. WAF applies
    #   fully qualified labels to matching web requests. A fully qualified
    #   label is the concatenation of a label namespace and a rule label.
    #   The rule's rule group or web ACL defines the label namespace.
    #
    #   For example,
    #   `awswaf:111122223333:myRuleGroup:testRules:testNS1:testNS2:labelNameA`
    #   or `awswaf:managed:aws:managed-rule-set:header:encoding:utf8`.
    #   @return [Array<Types::Label>]
    #
    # @!attribute [rw] captcha_response
    #   The `CAPTCHA` response for the request.
    #   @return [Types::CaptchaResponse]
    #
    # @!attribute [rw] challenge_response
    #   The `Challenge` response for the request.
    #   @return [Types::ChallengeResponse]
    #
    # @!attribute [rw] overridden_action
    #   Used only for rule group rules that have a rule action override in
    #   place in the web ACL. This is the action that the rule group rule is
    #   configured for, and not the action that was applied to the request.
    #   The action that WAF applied is the `Action` value.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/SampledHTTPRequest AWS API Documentation
    #
    class SampledHTTPRequest < Struct.new(
      :request,
      :weight,
      :timestamp,
      :action,
      :rule_name_within_rule_group,
      :request_headers_inserted,
      :response_code_sent,
      :labels,
      :captcha_response,
      :challenge_response,
      :overridden_action)
      SENSITIVE = []
      include Aws::Structure
    end

    # Inspect one of the headers in the web request, identified by name, for
    # example, `User-Agent` or `Referer`. The name isn't case sensitive.
    #
    # You can filter and inspect all headers with the `FieldToMatch` setting
    # `Headers`.
    #
    # This is used to indicate the web request component to inspect, in the
    # FieldToMatch specification.
    #
    # Example JSON: `"SingleHeader": { "Name": "haystack" }`
    #
    # @!attribute [rw] name
    #   The name of the query header to inspect.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/SingleHeader AWS API Documentation
    #
    class SingleHeader < Struct.new(
      :name)
      SENSITIVE = []
      include Aws::Structure
    end

    # Inspect one query argument in the web request, identified by name, for
    # example *UserName* or *SalesRegion*. The name isn't case sensitive.
    #
    # This is used to indicate the web request component to inspect, in the
    # FieldToMatch specification.
    #
    # Example JSON: `"SingleQueryArgument": { "Name": "myArgument" }`
    #
    # @!attribute [rw] name
    #   The name of the query argument to inspect.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/SingleQueryArgument AWS API Documentation
    #
    class SingleQueryArgument < Struct.new(
      :name)
      SENSITIVE = []
      include Aws::Structure
    end

    # A rule statement that compares a number of bytes against the size of a
    # request component, using a comparison operator, such as greater than
    # (&gt;) or less than (&lt;). For example, you can use a size constraint
    # statement to look for query strings that are longer than 100 bytes.
    #
    # If you configure WAF to inspect the request body, 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.
    #
    # @!attribute [rw] field_to_match
    #   The part of the web request that you want WAF to inspect.
    #   @return [Types::FieldToMatch]
    #
    # @!attribute [rw] comparison_operator
    #   The operator to use to compare the request part to the size setting.
    #   @return [String]
    #
    # @!attribute [rw] size
    #   The size, in byte, to compare to the request part, after any
    #   transformations.
    #   @return [Integer]
    #
    # @!attribute [rw] text_transformations
    #   Text transformations eliminate some of the unusual formatting that
    #   attackers use in web requests in an effort to bypass detection. Text
    #   transformations are used in rule match statements, to transform the
    #   `FieldToMatch` request component before inspecting it, and they're
    #   used in rate-based rule statements, to transform request components
    #   before using them as custom aggregation keys. If you specify one or
    #   more transformations to apply, WAF performs all transformations on
    #   the specified content, starting from the lowest priority setting,
    #   and then uses the transformed component contents.
    #   @return [Array<Types::TextTransformation>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/SizeConstraintStatement AWS API Documentation
    #
    class SizeConstraintStatement < Struct.new(
      :field_to_match,
      :comparison_operator,
      :size,
      :text_transformations)
      SENSITIVE = []
      include Aws::Structure
    end

    # 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.
    #
    # @!attribute [rw] field_to_match
    #   The part of the web request that you want WAF to inspect.
    #   @return [Types::FieldToMatch]
    #
    # @!attribute [rw] text_transformations
    #   Text transformations eliminate some of the unusual formatting that
    #   attackers use in web requests in an effort to bypass detection. Text
    #   transformations are used in rule match statements, to transform the
    #   `FieldToMatch` request component before inspecting it, and they're
    #   used in rate-based rule statements, to transform request components
    #   before using them as custom aggregation keys. If you specify one or
    #   more transformations to apply, WAF performs all transformations on
    #   the specified content, starting from the lowest priority setting,
    #   and then uses the transformed component contents.
    #   @return [Array<Types::TextTransformation>]
    #
    # @!attribute [rw] sensitivity_level
    #   The sensitivity that you want WAF to use to inspect for SQL
    #   injection attacks.
    #
    #   `HIGH` detects more attacks, but might generate more false
    #   positives, especially if your web requests frequently contain
    #   unusual strings. For information about identifying and mitigating
    #   false positives, see [Testing and tuning][1] in the *WAF Developer
    #   Guide*.
    #
    #   `LOW` is generally a better choice for resources that already have
    #   other protections against SQL injection attacks or that have a low
    #   tolerance for false positives.
    #
    #   Default: `LOW`
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/web-acl-testing.html
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/SqliMatchStatement AWS API Documentation
    #
    class SqliMatchStatement < Struct.new(
      :field_to_match,
      :text_transformations,
      :sensitivity_level)
      SENSITIVE = []
      include Aws::Structure
    end

    # The processing guidance for a Rule, used by WAF to determine whether a
    # web request matches the rule.
    #
    # For example specifications, see the examples section of CreateWebACL.
    #
    # @!attribute [rw] byte_match_statement
    #   A rule statement that defines a string match search for WAF to apply
    #   to web requests. The byte match statement provides the bytes to
    #   search for, the location in requests that you want WAF to search,
    #   and other settings. The bytes to search for are typically a string
    #   that corresponds with ASCII characters. In the WAF console and the
    #   developer guide, this is called a string match statement.
    #   @return [Types::ByteMatchStatement]
    #
    # @!attribute [rw] sqli_match_statement
    #   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.
    #   @return [Types::SqliMatchStatement]
    #
    # @!attribute [rw] xss_match_statement
    #   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.
    #   @return [Types::XssMatchStatement]
    #
    # @!attribute [rw] size_constraint_statement
    #   A rule statement that compares a number of bytes against the size of
    #   a request component, using a comparison operator, such as greater
    #   than (&gt;) or less than (&lt;). For example, you can use a size
    #   constraint statement to look for query strings that are longer than
    #   100 bytes.
    #
    #   If you configure WAF to inspect the request body, 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.
    #   @return [Types::SizeConstraintStatement]
    #
    # @!attribute [rw] geo_match_statement
    #   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 `CountryCodes` array.
    #
    #   * 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.
    #
    #   WAF labels requests using the alpha-2 country and region codes from
    #   the International Organization for Standardization (ISO) 3166
    #   standard. 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][1] in
    #   the [WAF Developer Guide][2].
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-rule-statement-type-geo-match.html
    #   [2]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-chapter.html
    #   @return [Types::GeoMatchStatement]
    #
    # @!attribute [rw] rule_group_reference_statement
    #   A rule statement used to run the rules that are defined in a
    #   RuleGroup. 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.
    #   @return [Types::RuleGroupReferenceStatement]
    #
    # @!attribute [rw] ip_set_reference_statement
    #   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.
    #   @return [Types::IPSetReferenceStatement]
    #
    # @!attribute [rw] regex_pattern_set_reference_statement
    #   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. To create a regex pattern set, see
    #   CreateRegexPatternSet.
    #
    #   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, WAF automatically updates all rules that
    #   reference it.
    #   @return [Types::RegexPatternSetReferenceStatement]
    #
    # @!attribute [rw] rate_based_statement
    #   A rate-based rule counts incoming requests and rate limits requests
    #   when they are coming at too fast a rate. The rule categorizes
    #   requests according to your aggregation criteria, collects them into
    #   aggregation instances, and counts and rate limits the requests for
    #   each instance.
    #
    #   <note markdown="1"> 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.
    #
    #    </note>
    #
    #   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:
    #
    #   * IP address 10.1.1.1, HTTP method POST
    #
    #   * IP address 10.1.1.1, HTTP method GET
    #
    #   * IP address 127.0.0.0, HTTP method POST
    #
    #   * IP address 10.1.1.1, HTTP method GET
    #
    #   The rule would create different aggregation instances according to
    #   your aggregation criteria, for example:
    #
    #   * If the aggregation criteria is just the IP address, then each
    #     individual address is an aggregation instance, and WAF counts
    #     requests separately for each. The aggregation instances and
    #     request counts for our example would be the following:
    #
    #     * IP address 10.1.1.1: count 3
    #
    #     * IP address 127.0.0.0: count 1
    #   * If the aggregation criteria is HTTP method, then each individual
    #     HTTP method is an aggregation instance. The aggregation instances
    #     and request counts for our example would be the following:
    #
    #     * HTTP method POST: count 2
    #
    #     * HTTP method GET: count 2
    #   * If the aggregation criteria is IP address and HTTP method, then
    #     each IP address and each HTTP method would contribute to the
    #     combined aggregation instance. The aggregation instances and
    #     request counts for our example would be the following:
    #
    #     * IP address 10.1.1.1, HTTP method POST: count 1
    #
    #     * IP address 10.1.1.1, HTTP method GET: count 2
    #
    #     * IP address 127.0.0.0, HTTP method POST: count 1
    #
    #   For any n-tuple of aggregation keys, each unique combination of
    #   values for the keys defines a separate aggregation instance, which
    #   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][1] in the *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 WAF is
    #   currently rate limiting for a rule through the API call
    #   `GetRateBasedStatementManagedKeys`. This option is not available for
    #   other aggregation configurations.
    #
    #   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 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 WAF.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-rate-based-rules.html
    #   @return [Types::RateBasedStatement]
    #
    # @!attribute [rw] and_statement
    #   A logical rule statement used to combine other rule statements with
    #   AND logic. You provide more than one Statement within the
    #   `AndStatement`.
    #   @return [Types::AndStatement]
    #
    # @!attribute [rw] or_statement
    #   A logical rule statement used to combine other rule statements with
    #   OR logic. You provide more than one Statement within the
    #   `OrStatement`.
    #   @return [Types::OrStatement]
    #
    # @!attribute [rw] not_statement
    #   A logical rule statement used to negate the results of another rule
    #   statement. You provide one Statement within the `NotStatement`.
    #   @return [Types::NotStatement]
    #
    # @!attribute [rw] managed_rule_group_statement
    #   A rule statement used to run the rules that are defined in a managed
    #   rule group. To use this, provide the vendor name and the name of the
    #   rule group in this statement. You can retrieve the required names by
    #   calling ListAvailableManagedRuleGroups.
    #
    #   You cannot nest a `ManagedRuleGroupStatement`, for example for use
    #   inside a `NotStatement` or `OrStatement`. You cannot use a managed
    #   rule group inside another rule group. You can only reference a
    #   managed rule group as a top-level statement within a rule that you
    #   define in a web ACL.
    #
    #   <note markdown="1"> You are charged additional fees when you use the WAF Bot Control
    #   managed rule group `AWSManagedRulesBotControlRuleSet`, the WAF Fraud
    #   Control account takeover prevention (ATP) managed rule group
    #   `AWSManagedRulesATPRuleSet`, or the WAF Fraud Control account
    #   creation fraud prevention (ACFP) managed rule group
    #   `AWSManagedRulesACFPRuleSet`. For more information, see [WAF
    #   Pricing][1].
    #
    #    </note>
    #
    #
    #
    #   [1]: http://aws.amazon.com/waf/pricing/
    #   @return [Types::ManagedRuleGroupStatement]
    #
    # @!attribute [rw] label_match_statement
    #   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, WAF performs the search for labels
    #   that were added in the same context as the label match statement.
    #   @return [Types::LabelMatchStatement]
    #
    # @!attribute [rw] regex_match_statement
    #   A rule statement used to search web request components for a match
    #   against a single regular expression.
    #   @return [Types::RegexMatchStatement]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/Statement AWS API Documentation
    #
    class Statement < Struct.new(
      :byte_match_statement,
      :sqli_match_statement,
      :xss_match_statement,
      :size_constraint_statement,
      :geo_match_statement,
      :rule_group_reference_statement,
      :ip_set_reference_statement,
      :regex_pattern_set_reference_statement,
      :rate_based_statement,
      :and_statement,
      :or_statement,
      :not_statement,
      :managed_rule_group_statement,
      :label_match_statement,
      :regex_match_statement)
      SENSITIVE = []
      include Aws::Structure
    end

    # A tag associated with an Amazon Web Services resource. Tags are
    # key:value pairs that you can use to categorize and manage your
    # resources, for purposes like billing or other management. Typically,
    # the tag key represents a category, such as "environment", and the
    # tag value represents a specific value within that category, such as
    # "test," "development," or "production". Or you might set the tag
    # key to "customer" and the value to the customer name or ID. You can
    # specify one or more tags to add to each Amazon Web Services resource,
    # up to 50 tags for a resource.
    #
    # You can tag the Amazon Web Services resources that you manage through
    # WAF: web ACLs, rule groups, IP sets, and regex pattern sets. You
    # can't manage or view tags through the WAF console.
    #
    # @!attribute [rw] key
    #   Part of the key:value pair that defines a tag. You can use a tag key
    #   to describe a category of information, such as "customer." Tag
    #   keys are case-sensitive.
    #   @return [String]
    #
    # @!attribute [rw] value
    #   Part of the key:value pair that defines a tag. You can use a tag
    #   value to describe a specific value within a category, such as
    #   "companyA" or "companyB." Tag values are case-sensitive.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/Tag AWS API Documentation
    #
    class Tag < Struct.new(
      :key,
      :value)
      SENSITIVE = []
      include Aws::Structure
    end

    # The collection of tagging definitions for an Amazon Web Services
    # resource. Tags are key:value pairs that you can use to categorize and
    # manage your resources, for purposes like billing or other management.
    # Typically, the tag key represents a category, such as "environment",
    # and the tag value represents a specific value within that category,
    # such as "test," "development," or "production". Or you might set
    # the tag key to "customer" and the value to the customer name or ID.
    # You can specify one or more tags to add to each Amazon Web Services
    # resource, up to 50 tags for a resource.
    #
    # You can tag the Amazon Web Services resources that you manage through
    # WAF: web ACLs, rule groups, IP sets, and regex pattern sets. You
    # can't manage or view tags through the WAF console.
    #
    # @!attribute [rw] resource_arn
    #   The Amazon Resource Name (ARN) of the resource.
    #   @return [String]
    #
    # @!attribute [rw] tag_list
    #   The array of Tag objects defined for the resource.
    #   @return [Array<Types::Tag>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/TagInfoForResource AWS API Documentation
    #
    class TagInfoForResource < Struct.new(
      :resource_arn,
      :tag_list)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] resource_arn
    #   The Amazon Resource Name (ARN) of the resource.
    #   @return [String]
    #
    # @!attribute [rw] tags
    #   An array of key:value pairs to associate with the resource.
    #   @return [Array<Types::Tag>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/TagResourceRequest AWS API Documentation
    #
    class TagResourceRequest < Struct.new(
      :resource_arn,
      :tags)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/TagResourceResponse AWS API Documentation
    #
    class TagResourceResponse < Aws::EmptyStructure; end

    # Text transformations eliminate some of the unusual formatting that
    # attackers use in web requests in an effort to bypass detection.
    #
    # @!attribute [rw] priority
    #   Sets the relative processing order for multiple transformations. WAF
    #   processes all transformations, from lowest priority to highest,
    #   before inspecting the transformed content. The priorities don't
    #   need to be consecutive, but they must all be different.
    #   @return [Integer]
    #
    # @!attribute [rw] type
    #   For detailed descriptions of each of the transformation types, see
    #   [Text transformations][1] in the *WAF Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-rule-statement-transformation.html
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/TextTransformation AWS API Documentation
    #
    class TextTransformation < Struct.new(
      :priority,
      :type)
      SENSITIVE = []
      include Aws::Structure
    end

    # In a GetSampledRequests request, the `StartTime` and `EndTime` objects
    # specify the time range for which you want WAF to return a sample of
    # web requests.
    #
    # You must specify the times in Coordinated Universal Time (UTC) format.
    # UTC format includes the special designator, `Z`. For example,
    # `"2016-09-27T14:50Z"`. You can specify any time range in the previous
    # three hours.
    #
    # In a GetSampledRequests response, the `StartTime` and `EndTime`
    # objects specify the time range for which WAF actually returned a
    # sample of web requests. WAF gets the specified number of requests from
    # among the first 5,000 requests that your Amazon Web Services resource
    # receives during the specified time period. If your resource receives
    # more than 5,000 requests during that period, WAF stops sampling after
    # the 5,000th request. In that case, `EndTime` is the time that WAF
    # received the 5,000th request.
    #
    # @!attribute [rw] start_time
    #   The beginning of the time range from which you want
    #   `GetSampledRequests` to return a sample of the requests that your
    #   Amazon Web Services resource received. You must specify the times in
    #   Coordinated Universal Time (UTC) format. UTC format includes the
    #   special designator, `Z`. For example, `"2016-09-27T14:50Z"`. You can
    #   specify any time range in the previous three hours.
    #   @return [Time]
    #
    # @!attribute [rw] end_time
    #   The end of the time range from which you want `GetSampledRequests`
    #   to return a sample of the requests that your Amazon Web Services
    #   resource received. You must specify the times in Coordinated
    #   Universal Time (UTC) format. UTC format includes the special
    #   designator, `Z`. For example, `"2016-09-27T14:50Z"`. You can specify
    #   any time range in the previous three hours.
    #   @return [Time]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/TimeWindow AWS API Documentation
    #
    class TimeWindow < Struct.new(
      :start_time,
      :end_time)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] resource_arn
    #   The Amazon Resource Name (ARN) of the resource.
    #   @return [String]
    #
    # @!attribute [rw] tag_keys
    #   An array of keys identifying the tags to disassociate from the
    #   resource.
    #   @return [Array<String>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UntagResourceRequest AWS API Documentation
    #
    class UntagResourceRequest < Struct.new(
      :resource_arn,
      :tag_keys)
      SENSITIVE = []
      include Aws::Structure
    end

    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UntagResourceResponse AWS API Documentation
    #
    class UntagResourceResponse < Aws::EmptyStructure; end

    # @!attribute [rw] name
    #   The name of the IP set. You cannot change the name of an `IPSet`
    #   after you create it.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the set. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   A description of the IP set that helps with identification.
    #   @return [String]
    #
    # @!attribute [rw] addresses
    #   Contains an array of strings that specifies zero or more IP
    #   addresses or blocks of IP addresses that you want WAF to inspect for
    #   in incoming requests. All addresses must be specified using
    #   Classless Inter-Domain Routing (CIDR) notation. WAF supports all
    #   IPv4 and IPv6 CIDR ranges except for `/0`.
    #
    #   Example address strings:
    #
    #   * For requests that originated from the IP address 192.0.2.44,
    #     specify `192.0.2.44/32`.
    #
    #   * For requests that originated from IP addresses from 192.0.2.0 to
    #     192.0.2.255, specify `192.0.2.0/24`.
    #
    #   * For 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`.
    #
    #   * For 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`.
    #
    #   For more information about CIDR notation, see the Wikipedia entry
    #   [Classless Inter-Domain Routing][1].
    #
    #   Example JSON `Addresses` specifications:
    #
    #   * Empty array: `"Addresses": []`
    #
    #   * Array with one address: `"Addresses": ["192.0.2.44/32"]`
    #
    #   * Array with three addresses: `"Addresses": ["192.0.2.44/32",
    #     "192.0.2.0/24", "192.0.0.0/16"]`
    #
    #   * INVALID specification: `"Addresses": [""]` INVALID
    #
    #
    #
    #   [1]: https://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing
    #   @return [Array<String>]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateIPSetRequest AWS API Documentation
    #
    class UpdateIPSetRequest < Struct.new(
      :name,
      :scope,
      :id,
      :description,
      :addresses,
      :lock_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_lock_token
    #   A token used for optimistic locking. WAF returns this token to your
    #   `update` requests. You use `NextLockToken` in the same manner as you
    #   use `LockToken`.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateIPSetResponse AWS API Documentation
    #
    class UpdateIPSetResponse < Struct.new(
      :next_lock_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] name
    #   The name of the managed rule set. You use this, along with the rule
    #   set ID, to identify the rule set.
    #
    #   This name is assigned to the corresponding managed rule group, which
    #   your customers can access and use.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the managed rule set. The ID is returned in
    #   the responses to commands like `list`. You provide it to operations
    #   like `get` and `update`.
    #   @return [String]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @!attribute [rw] version_to_expire
    #   The version that you want to remove from your list of offerings for
    #   the named managed rule group.
    #   @return [String]
    #
    # @!attribute [rw] expiry_timestamp
    #   The time that you want the version to expire.
    #
    #   Times are in Coordinated Universal Time (UTC) format. UTC format
    #   includes the special designator, Z. For example,
    #   "2016-09-27T14:50Z".
    #   @return [Time]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateManagedRuleSetVersionExpiryDateRequest AWS API Documentation
    #
    class UpdateManagedRuleSetVersionExpiryDateRequest < Struct.new(
      :name,
      :scope,
      :id,
      :lock_token,
      :version_to_expire,
      :expiry_timestamp)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] expiring_version
    #   The version that is set to expire.
    #   @return [String]
    #
    # @!attribute [rw] expiry_timestamp
    #   The time that the version will expire.
    #
    #   Times are in Coordinated Universal Time (UTC) format. UTC format
    #   includes the special designator, Z. For example,
    #   "2016-09-27T14:50Z".
    #   @return [Time]
    #
    # @!attribute [rw] next_lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateManagedRuleSetVersionExpiryDateResponse AWS API Documentation
    #
    class UpdateManagedRuleSetVersionExpiryDateResponse < Struct.new(
      :expiring_version,
      :expiry_timestamp,
      :next_lock_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] name
    #   The name of the set. You cannot change the name after you create the
    #   set.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the set. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   A description of the set that helps with identification.
    #   @return [String]
    #
    # @!attribute [rw] regular_expression_list
    #   @return [Array<Types::Regex>]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateRegexPatternSetRequest AWS API Documentation
    #
    class UpdateRegexPatternSetRequest < Struct.new(
      :name,
      :scope,
      :id,
      :description,
      :regular_expression_list,
      :lock_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_lock_token
    #   A token used for optimistic locking. WAF returns this token to your
    #   `update` requests. You use `NextLockToken` in the same manner as you
    #   use `LockToken`.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateRegexPatternSetResponse AWS API Documentation
    #
    class UpdateRegexPatternSetResponse < Struct.new(
      :next_lock_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] name
    #   The name of the rule group. You cannot change the name of a rule
    #   group after you create it.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the rule group. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   A description of the rule group that helps with identification.
    #   @return [String]
    #
    # @!attribute [rw] rules
    #   The Rule statements used to identify the web requests that you want
    #   to manage. Each rule includes one top-level statement that WAF uses
    #   to identify matching web requests, and parameters that govern how
    #   WAF handles them.
    #   @return [Array<Types::Rule>]
    #
    # @!attribute [rw] visibility_config
    #   Defines and enables Amazon CloudWatch metrics and web request sample
    #   collection.
    #   @return [Types::VisibilityConfig]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @!attribute [rw] custom_response_bodies
    #   A map of custom response keys and content bodies. When you create a
    #   rule with a block action, you can send a custom response to the web
    #   request. You define these for the rule group, and then use them in
    #   the rules that you define in the rule group.
    #
    #   For information about customizing web requests and responses, see
    #   [Customizing web requests and responses in WAF][1] in the *WAF
    #   Developer Guide*.
    #
    #   For information about the limits on count and size for custom
    #   request and response settings, see [WAF quotas][2] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html
    #   [2]: https://docs.aws.amazon.com/waf/latest/developerguide/limits.html
    #   @return [Hash<String,Types::CustomResponseBody>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateRuleGroupRequest AWS API Documentation
    #
    class UpdateRuleGroupRequest < Struct.new(
      :name,
      :scope,
      :id,
      :description,
      :rules,
      :visibility_config,
      :lock_token,
      :custom_response_bodies)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_lock_token
    #   A token used for optimistic locking. WAF returns this token to your
    #   `update` requests. You use `NextLockToken` in the same manner as you
    #   use `LockToken`.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateRuleGroupResponse AWS API Documentation
    #
    class UpdateRuleGroupResponse < Struct.new(
      :next_lock_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] name
    #   The name of the web ACL. You cannot change the name of a web ACL
    #   after you create it.
    #   @return [String]
    #
    # @!attribute [rw] scope
    #   Specifies whether this is for an Amazon CloudFront distribution or
    #   for a regional application. A regional application can be an
    #   Application Load Balancer (ALB), an Amazon API Gateway REST API, an
    #   AppSync GraphQL API, an Amazon Cognito user pool, an App Runner
    #   service, or an Amazon Web Services Verified Access instance.
    #
    #   To work with CloudFront, you must also specify the Region US East
    #   (N. Virginia) as follows:
    #
    #   * CLI - Specify the Region when you use the CloudFront scope:
    #     `--scope=CLOUDFRONT --region=us-east-1`.
    #
    #   * API and SDKs - For all calls, use the Region endpoint us-east-1.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   The unique identifier for the web ACL. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @!attribute [rw] default_action
    #   The action to perform if none of the `Rules` contained in the
    #   `WebACL` match.
    #   @return [Types::DefaultAction]
    #
    # @!attribute [rw] description
    #   A description of the web ACL that helps with identification.
    #   @return [String]
    #
    # @!attribute [rw] rules
    #   The Rule statements used to identify the web requests that you want
    #   to manage. Each rule includes one top-level statement that WAF uses
    #   to identify matching web requests, and parameters that govern how
    #   WAF handles them.
    #   @return [Array<Types::Rule>]
    #
    # @!attribute [rw] visibility_config
    #   Defines and enables Amazon CloudWatch metrics and web request sample
    #   collection.
    #   @return [Types::VisibilityConfig]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @!attribute [rw] custom_response_bodies
    #   A map of custom response keys and content bodies. When you create a
    #   rule with a block action, you can send a custom response to the web
    #   request. You define these for the web ACL, and then use them in the
    #   rules and default actions that you define in the web ACL.
    #
    #   For information about customizing web requests and responses, see
    #   [Customizing web requests and responses in WAF][1] in the *WAF
    #   Developer Guide*.
    #
    #   For information about the limits on count and size for custom
    #   request and response settings, see [WAF quotas][2] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html
    #   [2]: https://docs.aws.amazon.com/waf/latest/developerguide/limits.html
    #   @return [Hash<String,Types::CustomResponseBody>]
    #
    # @!attribute [rw] captcha_config
    #   Specifies how WAF should handle `CAPTCHA` evaluations for rules that
    #   don't have their own `CaptchaConfig` settings. If you don't
    #   specify this, WAF uses its default settings for `CaptchaConfig`.
    #   @return [Types::CaptchaConfig]
    #
    # @!attribute [rw] challenge_config
    #   Specifies how WAF should handle challenge evaluations for rules that
    #   don't have their own `ChallengeConfig` settings. If you don't
    #   specify this, WAF uses its default settings for `ChallengeConfig`.
    #   @return [Types::ChallengeConfig]
    #
    # @!attribute [rw] token_domains
    #   Specifies the domains that WAF should accept in a web request token.
    #   This enables the use of tokens across multiple protected websites.
    #   When WAF provides a token, it uses the domain of the Amazon Web
    #   Services resource that the web ACL is protecting. If you don't
    #   specify a list of token domains, WAF accepts tokens only for the
    #   domain of the protected resource. With a token domain list, WAF
    #   accepts the resource's host domain plus all domains in the token
    #   domain list, including their prefixed subdomains.
    #
    #   Example JSON: `"TokenDomains": { "mywebsite.com",
    #   "myotherwebsite.com" }`
    #
    #   Public suffixes aren't allowed. For example, you can't use
    #   `gov.au` or `co.uk` as token domains.
    #   @return [Array<String>]
    #
    # @!attribute [rw] association_config
    #   Specifies custom configurations for the associations between the web
    #   ACL and protected resources.
    #
    #   Use this to customize the maximum size of the request body that your
    #   protected resources forward to WAF for inspection. You can customize
    #   this setting for CloudFront, API Gateway, Amazon Cognito, App
    #   Runner, or Verified Access resources. The default setting is 16 KB
    #   (16,384 bytes).
    #
    #   <note markdown="1"> You are charged additional fees when your protected resources
    #   forward body sizes that are larger than the default. For more
    #   information, see [WAF Pricing][1].
    #
    #    </note>
    #
    #   For Application Load Balancer and AppSync, the limit is fixed at 8
    #   KB (8,192 bytes).
    #
    #
    #
    #   [1]: http://aws.amazon.com/waf/pricing/
    #   @return [Types::AssociationConfig]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateWebACLRequest AWS API Documentation
    #
    class UpdateWebACLRequest < Struct.new(
      :name,
      :scope,
      :id,
      :default_action,
      :description,
      :rules,
      :visibility_config,
      :lock_token,
      :custom_response_bodies,
      :captcha_config,
      :challenge_config,
      :token_domains,
      :association_config)
      SENSITIVE = []
      include Aws::Structure
    end

    # @!attribute [rw] next_lock_token
    #   A token used for optimistic locking. WAF returns this token to your
    #   `update` requests. You use `NextLockToken` in the same manner as you
    #   use `LockToken`.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UpdateWebACLResponse AWS API Documentation
    #
    class UpdateWebACLResponse < Struct.new(
      :next_lock_token)
      SENSITIVE = []
      include Aws::Structure
    end

    # Inspect the path component of the URI of the web request. This is the
    # part of the web request that identifies a resource. For example,
    # `/images/daily-ad.jpg`.
    #
    # This is used in the FieldToMatch specification for some web request
    # component types.
    #
    # JSON specification: `"UriPath": {}`
    #
    # @api private
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UriPath AWS API Documentation
    #
    class UriPath < Aws::EmptyStructure; end

    # The name of the field in the request payload that contains your
    # customer's username.
    #
    # This data type is used in the `RequestInspection` and
    # `RequestInspectionACFP` data types.
    #
    # @!attribute [rw] identifier
    #   The name of the username field.
    #
    #   How you specify this depends on the request inspection payload type.
    #
    #   * For JSON payloads, specify the field name in JSON pointer syntax.
    #     For information about the JSON Pointer syntax, see the Internet
    #     Engineering Task Force (IETF) documentation [JavaScript Object
    #     Notation (JSON) Pointer][1].
    #
    #     For example, for the JSON payload `{ "form": { "username":
    #     "THE_USERNAME" } }`, the username field specification is
    #     `/form/username`.
    #
    #   * For form encoded payload types, use the HTML form names.
    #
    #     For example, for an HTML form with the input element named
    #     `username1`, the username field specification is `username1`
    #
    #
    #
    #   [1]: https://tools.ietf.org/html/rfc6901
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/UsernameField AWS API Documentation
    #
    class UsernameField < Struct.new(
      :identifier)
      SENSITIVE = []
      include Aws::Structure
    end

    # A version of the named managed rule group, that the rule group's
    # vendor publishes for use by customers.
    #
    # <note markdown="1"> This is intended for use only by vendors of managed rule sets. Vendors
    # are Amazon Web Services and Amazon Web Services Marketplace sellers.
    #
    #  Vendors, you can use the managed rule set APIs to provide controlled
    # rollout of your versioned managed rule group offerings for your
    # customers. The APIs are `ListManagedRuleSets`, `GetManagedRuleSet`,
    # `PutManagedRuleSetVersions`, and
    # `UpdateManagedRuleSetVersionExpiryDate`.
    #
    #  </note>
    #
    # @!attribute [rw] associated_rule_group_arn
    #   The Amazon Resource Name (ARN) of the vendor's rule group that's
    #   used in the published managed rule group version.
    #   @return [String]
    #
    # @!attribute [rw] forecasted_lifetime
    #   The amount of time the vendor expects this version of the managed
    #   rule group to last, in days.
    #   @return [Integer]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/VersionToPublish AWS API Documentation
    #
    class VersionToPublish < Struct.new(
      :associated_rule_group_arn,
      :forecasted_lifetime)
      SENSITIVE = []
      include Aws::Structure
    end

    # Defines and enables Amazon CloudWatch metrics and web request sample
    # collection.
    #
    # @!attribute [rw] sampled_requests_enabled
    #   Indicates whether WAF should store a sampling of the web requests
    #   that match the rules. You can view the sampled requests through the
    #   WAF console.
    #
    #   <note markdown="1"> Request sampling doesn't provide a field redaction option, and any
    #   field redaction that you specify in your logging configuration
    #   doesn't affect sampling. The only way to exclude fields from
    #   request sampling is by disabling sampling in the web ACL visibility
    #   configuration.
    #
    #    </note>
    #   @return [Boolean]
    #
    # @!attribute [rw] cloud_watch_metrics_enabled
    #   Indicates whether the associated resource sends metrics to Amazon
    #   CloudWatch. For the list of available metrics, see [WAF Metrics][1]
    #   in the *WAF Developer Guide*.
    #
    #   For web ACLs, the metrics are for web requests that have the web ACL
    #   default action applied. WAF applies the default action to web
    #   requests that pass the inspection of all rules in the web ACL
    #   without being either allowed or blocked. For more information, see
    #   [The web ACL default action][2] in the *WAF Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/monitoring-cloudwatch.html#waf-metrics
    #   [2]: https://docs.aws.amazon.com/waf/latest/developerguide/web-acl-default-action.html
    #   @return [Boolean]
    #
    # @!attribute [rw] metric_name
    #   A name of the Amazon CloudWatch metric dimension. The name can
    #   contain only the characters: A-Z, a-z, 0-9, - (hyphen), and \_
    #   (underscore). The name can be from one to 128 characters long. It
    #   can't contain whitespace or metric names that are reserved for WAF,
    #   for example `All` and `Default_Action`.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/VisibilityConfig AWS API Documentation
    #
    class VisibilityConfig < Struct.new(
      :sampled_requests_enabled,
      :cloud_watch_metrics_enabled,
      :metric_name)
      SENSITIVE = []
      include Aws::Structure
    end

    # WAF couldn’t perform the operation because your resource is being used
    # by another resource or it’s associated with another resource.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WAFAssociatedItemException AWS API Documentation
    #
    class WAFAssociatedItemException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # The operation failed because you are inspecting the web request body,
    # headers, or cookies without specifying how to handle oversize
    # components. Rules that inspect the body must either provide an
    # `OversizeHandling` configuration or they must be preceded by a
    # `SizeConstraintStatement` that blocks the body content from being too
    # large. Rules that inspect the headers or cookies must provide an
    # `OversizeHandling` configuration.
    #
    # Provide the handling configuration and retry your operation.
    #
    # Alternately, you can suppress this warning by adding the following tag
    # to the resource that you provide to this operation: `Tag`
    # (key:`WAF:OversizeFieldsHandlingConstraintOptOut`, value:`true`).
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WAFConfigurationWarningException AWS API Documentation
    #
    class WAFConfigurationWarningException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # WAF couldn’t perform the operation because the resource that you tried
    # to save is a duplicate of an existing one.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WAFDuplicateItemException AWS API Documentation
    #
    class WAFDuplicateItemException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # The operation failed because the specified version for the managed
    # rule group has expired. You can retrieve the available versions for
    # the managed rule group by calling
    # ListAvailableManagedRuleGroupVersions.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WAFExpiredManagedRuleGroupVersionException AWS API Documentation
    #
    class WAFExpiredManagedRuleGroupVersionException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # Your request is valid, but WAF couldn’t perform the operation because
    # of a system problem. Retry your request.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WAFInternalErrorException AWS API Documentation
    #
    class WAFInternalErrorException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # The operation isn't valid.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WAFInvalidOperationException AWS API Documentation
    #
    class WAFInvalidOperationException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # The operation failed because WAF didn't recognize a parameter in the
    # request. For example:
    #
    # * You specified a parameter name or value that isn't valid.
    #
    # * Your nested statement isn't valid. You might have tried to nest a
    #   statement that can’t be nested.
    #
    # * You tried to update a `WebACL` with a `DefaultAction` that isn't
    #   among the types available at DefaultAction.
    #
    # * Your request references an ARN that is malformed, or corresponds to
    #   a resource with which a web ACL can't be associated.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @!attribute [rw] field
    #   The settings where the invalid parameter was found.
    #   @return [String]
    #
    # @!attribute [rw] parameter
    #   The invalid parameter that resulted in the exception.
    #   @return [String]
    #
    # @!attribute [rw] reason
    #   Additional information about the exception.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WAFInvalidParameterException AWS API Documentation
    #
    class WAFInvalidParameterException < Struct.new(
      :message,
      :field,
      :parameter,
      :reason)
      SENSITIVE = []
      include Aws::Structure
    end

    # The operation failed because the specified policy isn't in the proper
    # format.
    #
    # The policy specifications must conform to the following:
    #
    # * The policy must be composed using IAM Policy version 2012-10-17.
    #
    # * The policy must include specifications for `Effect`, `Action`, and
    #   `Principal`.
    #
    # * `Effect` must specify `Allow`.
    #
    # * `Action` must specify `wafv2:CreateWebACL`, `wafv2:UpdateWebACL`,
    #   and `wafv2:PutFirewallManagerRuleGroups` and may optionally specify
    #   `wafv2:GetRuleGroup`. WAF rejects any extra actions or wildcard
    #   actions in the policy.
    #
    # * The policy must not include a `Resource` parameter.
    #
    # For more information, see [IAM Policies][1].
    #
    #
    #
    # [1]: https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies.html
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WAFInvalidPermissionPolicyException AWS API Documentation
    #
    class WAFInvalidPermissionPolicyException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # WAF couldn’t perform the operation because the resource that you
    # requested isn’t valid. Check the resource, and try again.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WAFInvalidResourceException AWS API Documentation
    #
    class WAFInvalidResourceException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # WAF couldn’t perform the operation because you exceeded your resource
    # limit. For example, the maximum number of `WebACL` objects that you
    # can create for an Amazon Web Services account. For more information,
    # see [WAF quotas][1] in the *WAF Developer Guide*.
    #
    #
    #
    # [1]: https://docs.aws.amazon.com/waf/latest/developerguide/limits.html
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @!attribute [rw] source_type
    #   Source type for the exception.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WAFLimitsExceededException AWS API Documentation
    #
    class WAFLimitsExceededException < Struct.new(
      :message,
      :source_type)
      SENSITIVE = []
      include Aws::Structure
    end

    # The operation failed because you don't have the permissions that your
    # logging configuration requires. For information, see [Logging web ACL
    # traffic information][1] in the *WAF Developer Guide*.
    #
    #
    #
    # [1]: https://docs.aws.amazon.com/waf/latest/developerguide/logging.html
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WAFLogDestinationPermissionIssueException AWS API Documentation
    #
    class WAFLogDestinationPermissionIssueException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # WAF couldn’t perform the operation because your resource doesn't
    # exist. If you've just created a resource that you're using in this
    # operation, you might just need to wait a few minutes. It can take from
    # a few seconds to a number of minutes for changes to propagate.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WAFNonexistentItemException AWS API Documentation
    #
    class WAFNonexistentItemException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # WAF couldn’t save your changes because you tried to update or delete a
    # resource that has changed since you last retrieved it. Get the
    # resource again, make any changes you need to make to the new copy, and
    # retry your operation.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WAFOptimisticLockException AWS API Documentation
    #
    class WAFOptimisticLockException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # WAF is not able to access the service linked role. This can be caused
    # by a previous `PutLoggingConfiguration` request, which can lock the
    # service linked role for about 20 seconds. Please try your request
    # again. The service linked role can also be locked by a previous
    # `DeleteServiceLinkedRole` request, which can lock the role for 15
    # minutes or more. If you recently made a call to
    # `DeleteServiceLinkedRole`, wait at least 15 minutes and try the
    # request again. If you receive this same exception again, you will have
    # to wait additional time until the role is unlocked.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WAFServiceLinkedRoleErrorException AWS API Documentation
    #
    class WAFServiceLinkedRoleErrorException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # You tried to use a managed rule group that's available by
    # subscription, but you aren't subscribed to it yet.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WAFSubscriptionNotFoundException AWS API Documentation
    #
    class WAFSubscriptionNotFoundException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # An error occurred during the tagging operation. Retry your request.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WAFTagOperationException AWS API Documentation
    #
    class WAFTagOperationException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # WAF couldn’t perform your tagging operation because of an internal
    # error. Retry your request.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WAFTagOperationInternalErrorException AWS API Documentation
    #
    class WAFTagOperationInternalErrorException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # WAF couldn’t retrieve a resource that you specified for this
    # operation. If you've just created a resource that you're using in
    # this operation, you might just need to wait a few minutes. It can take
    # from a few seconds to a number of minutes for changes to propagate.
    # Verify the resources that you are specifying in your request
    # parameters and then retry the operation.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WAFUnavailableEntityException AWS API Documentation
    #
    class WAFUnavailableEntityException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # The rule that you've named doesn't aggregate solely on the IP
    # address or solely on the forwarded IP address. This call is only
    # available for rate-based rules with an `AggregateKeyType` setting of
    # `IP` or `FORWARDED_IP`.
    #
    # @!attribute [rw] message
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WAFUnsupportedAggregateKeyTypeException AWS API Documentation
    #
    class WAFUnsupportedAggregateKeyTypeException < Struct.new(
      :message)
      SENSITIVE = []
      include Aws::Structure
    end

    # A web ACL defines a collection of rules to use to inspect and control
    # web requests. Each rule has a statement that defines what to look for
    # in web requests and an action that WAF applies to requests that match
    # the statement. In the web ACL, you assign a default action to take
    # (allow, block) for any request that does not match any of the rules.
    # The rules in a web ACL can be a combination of the types Rule,
    # RuleGroup, and managed rule group. You can associate a web ACL with
    # one or more Amazon Web Services resources to protect. The resources
    # can be an Amazon CloudFront distribution, an Amazon API Gateway REST
    # API, an Application Load Balancer, an AppSync GraphQL API, an Amazon
    # Cognito user pool, an App Runner service, or an Amazon Web Services
    # Verified Access instance.
    #
    # @!attribute [rw] name
    #   The name of the web ACL. You cannot change the name of a web ACL
    #   after you create it.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   A unique identifier for the `WebACL`. This ID is returned in the
    #   responses to create and list commands. You use this ID to do things
    #   like get, update, and delete a `WebACL`.
    #   @return [String]
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the web ACL that you want to
    #   associate with the resource.
    #   @return [String]
    #
    # @!attribute [rw] default_action
    #   The action to perform if none of the `Rules` contained in the
    #   `WebACL` match.
    #   @return [Types::DefaultAction]
    #
    # @!attribute [rw] description
    #   A description of the web ACL that helps with identification.
    #   @return [String]
    #
    # @!attribute [rw] rules
    #   The Rule statements used to identify the web requests that you want
    #   to manage. Each rule includes one top-level statement that WAF uses
    #   to identify matching web requests, and parameters that govern how
    #   WAF handles them.
    #   @return [Array<Types::Rule>]
    #
    # @!attribute [rw] visibility_config
    #   Defines and enables Amazon CloudWatch metrics and web request sample
    #   collection.
    #   @return [Types::VisibilityConfig]
    #
    # @!attribute [rw] capacity
    #   The web ACL capacity units (WCUs) currently being used by this web
    #   ACL.
    #
    #   WAF uses WCUs to calculate and control the operating resources that
    #   are used to run your rules, rule groups, and web ACLs. WAF
    #   calculates capacity differently for each rule type, to reflect the
    #   relative cost of each rule. Simple rules that cost little to run use
    #   fewer WCUs than more complex rules that use more processing power.
    #   Rule group capacity is fixed at creation, which helps users plan
    #   their web ACL WCU usage when they use a rule group. For more
    #   information, see [WAF web ACL capacity units (WCU)][1] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/aws-waf-capacity-units.html
    #   @return [Integer]
    #
    # @!attribute [rw] pre_process_firewall_manager_rule_groups
    #   The first set of rules for WAF to process in the web ACL. This is
    #   defined in an Firewall Manager WAF policy and contains only rule
    #   group references. You can't alter these. Any rules and rule groups
    #   that you define for the web ACL are prioritized after these.
    #
    #   In the Firewall Manager WAF policy, the Firewall Manager
    #   administrator can define a set of rule groups to run first in the
    #   web ACL and a set of rule groups to run last. Within each set, the
    #   administrator prioritizes the rule groups, to determine their
    #   relative processing order.
    #   @return [Array<Types::FirewallManagerRuleGroup>]
    #
    # @!attribute [rw] post_process_firewall_manager_rule_groups
    #   The last set of rules for WAF to process in the web ACL. This is
    #   defined in an Firewall Manager WAF policy and contains only rule
    #   group references. You can't alter these. Any rules and rule groups
    #   that you define for the web ACL are prioritized before these.
    #
    #   In the Firewall Manager WAF policy, the Firewall Manager
    #   administrator can define a set of rule groups to run first in the
    #   web ACL and a set of rule groups to run last. Within each set, the
    #   administrator prioritizes the rule groups, to determine their
    #   relative processing order.
    #   @return [Array<Types::FirewallManagerRuleGroup>]
    #
    # @!attribute [rw] managed_by_firewall_manager
    #   Indicates whether this web ACL was created by Firewall Manager and
    #   is being managed by Firewall Manager. If true, then only Firewall
    #   Manager can delete the web ACL or any Firewall Manager rule groups
    #   in the web ACL. See also the properties
    #   `RetrofittedByFirewallManager`,
    #   `PreProcessFirewallManagerRuleGroups`, and
    #   `PostProcessFirewallManagerRuleGroups`.
    #   @return [Boolean]
    #
    # @!attribute [rw] label_namespace
    #   The label namespace prefix for this web ACL. All labels added by
    #   rules in this web ACL have this prefix.
    #
    #   * The syntax for the label namespace prefix for a web ACL is the
    #     following:
    #
    #     `awswaf:<account ID>:webacl:<web ACL name>:`
    #
    #   * When a rule with a label matches a web request, WAF adds the fully
    #     qualified label to the request. A fully qualified label is made up
    #     of the label namespace from the rule group or web ACL where the
    #     rule is defined and the label from the rule, separated by a colon:
    #
    #     `<label namespace>:<label from rule>`
    #   @return [String]
    #
    # @!attribute [rw] custom_response_bodies
    #   A map of custom response keys and content bodies. When you create a
    #   rule with a block action, you can send a custom response to the web
    #   request. You define these for the web ACL, and then use them in the
    #   rules and default actions that you define in the web ACL.
    #
    #   For information about customizing web requests and responses, see
    #   [Customizing web requests and responses in WAF][1] in the *WAF
    #   Developer Guide*.
    #
    #   For information about the limits on count and size for custom
    #   request and response settings, see [WAF quotas][2] in the *WAF
    #   Developer Guide*.
    #
    #
    #
    #   [1]: https://docs.aws.amazon.com/waf/latest/developerguide/waf-custom-request-response.html
    #   [2]: https://docs.aws.amazon.com/waf/latest/developerguide/limits.html
    #   @return [Hash<String,Types::CustomResponseBody>]
    #
    # @!attribute [rw] captcha_config
    #   Specifies how WAF should handle `CAPTCHA` evaluations for rules that
    #   don't have their own `CaptchaConfig` settings. If you don't
    #   specify this, WAF uses its default settings for `CaptchaConfig`.
    #   @return [Types::CaptchaConfig]
    #
    # @!attribute [rw] challenge_config
    #   Specifies how WAF should handle challenge evaluations for rules that
    #   don't have their own `ChallengeConfig` settings. If you don't
    #   specify this, WAF uses its default settings for `ChallengeConfig`.
    #   @return [Types::ChallengeConfig]
    #
    # @!attribute [rw] token_domains
    #   Specifies the domains that WAF should accept in a web request token.
    #   This enables the use of tokens across multiple protected websites.
    #   When WAF provides a token, it uses the domain of the Amazon Web
    #   Services resource that the web ACL is protecting. If you don't
    #   specify a list of token domains, WAF accepts tokens only for the
    #   domain of the protected resource. With a token domain list, WAF
    #   accepts the resource's host domain plus all domains in the token
    #   domain list, including their prefixed subdomains.
    #   @return [Array<String>]
    #
    # @!attribute [rw] association_config
    #   Specifies custom configurations for the associations between the web
    #   ACL and protected resources.
    #
    #   Use this to customize the maximum size of the request body that your
    #   protected resources forward to WAF for inspection. You can customize
    #   this setting for CloudFront, API Gateway, Amazon Cognito, App
    #   Runner, or Verified Access resources. The default setting is 16 KB
    #   (16,384 bytes).
    #
    #   <note markdown="1"> You are charged additional fees when your protected resources
    #   forward body sizes that are larger than the default. For more
    #   information, see [WAF Pricing][1].
    #
    #    </note>
    #
    #   For Application Load Balancer and AppSync, the limit is fixed at 8
    #   KB (8,192 bytes).
    #
    #
    #
    #   [1]: http://aws.amazon.com/waf/pricing/
    #   @return [Types::AssociationConfig]
    #
    # @!attribute [rw] retrofitted_by_firewall_manager
    #   Indicates whether this web ACL was created by a customer account and
    #   then retrofitted by Firewall Manager. If true, then the web ACL is
    #   currently being managed by a Firewall Manager WAF policy, and only
    #   Firewall Manager can manage any Firewall Manager rule groups in the
    #   web ACL. See also the properties `ManagedByFirewallManager`,
    #   `PreProcessFirewallManagerRuleGroups`, and
    #   `PostProcessFirewallManagerRuleGroups`.
    #   @return [Boolean]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WebACL AWS API Documentation
    #
    class WebACL < Struct.new(
      :name,
      :id,
      :arn,
      :default_action,
      :description,
      :rules,
      :visibility_config,
      :capacity,
      :pre_process_firewall_manager_rule_groups,
      :post_process_firewall_manager_rule_groups,
      :managed_by_firewall_manager,
      :label_namespace,
      :custom_response_bodies,
      :captcha_config,
      :challenge_config,
      :token_domains,
      :association_config,
      :retrofitted_by_firewall_manager)
      SENSITIVE = []
      include Aws::Structure
    end

    # High-level information about a WebACL, returned by operations like
    # create and list. This provides information like the ID, that you can
    # use to retrieve and manage a `WebACL`, and the ARN, that you provide
    # to operations like AssociateWebACL.
    #
    # @!attribute [rw] name
    #   The name of the web ACL. You cannot change the name of a web ACL
    #   after you create it.
    #   @return [String]
    #
    # @!attribute [rw] id
    #   The unique identifier for the web ACL. This ID is returned in the
    #   responses to create and list commands. You provide it to operations
    #   like update and delete.
    #   @return [String]
    #
    # @!attribute [rw] description
    #   A description of the web ACL that helps with identification.
    #   @return [String]
    #
    # @!attribute [rw] lock_token
    #   A token used for optimistic locking. WAF returns a token to your
    #   `get` and `list` requests, to mark the state of the entity at the
    #   time of the request. To make changes to the entity associated with
    #   the token, you provide the token to operations like `update` and
    #   `delete`. WAF uses the token to ensure that no changes have been
    #   made to the entity since you last retrieved it. If a change has been
    #   made, the update fails with a `WAFOptimisticLockException`. If this
    #   happens, perform another `get`, and use the new token returned by
    #   that operation.
    #   @return [String]
    #
    # @!attribute [rw] arn
    #   The Amazon Resource Name (ARN) of the entity.
    #   @return [String]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/WebACLSummary AWS API Documentation
    #
    class WebACLSummary < Struct.new(
      :name,
      :id,
      :description,
      :lock_token,
      :arn)
      SENSITIVE = []
      include Aws::Structure
    end

    # 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.
    #
    # @!attribute [rw] field_to_match
    #   The part of the web request that you want WAF to inspect.
    #   @return [Types::FieldToMatch]
    #
    # @!attribute [rw] text_transformations
    #   Text transformations eliminate some of the unusual formatting that
    #   attackers use in web requests in an effort to bypass detection. Text
    #   transformations are used in rule match statements, to transform the
    #   `FieldToMatch` request component before inspecting it, and they're
    #   used in rate-based rule statements, to transform request components
    #   before using them as custom aggregation keys. If you specify one or
    #   more transformations to apply, WAF performs all transformations on
    #   the specified content, starting from the lowest priority setting,
    #   and then uses the transformed component contents.
    #   @return [Array<Types::TextTransformation>]
    #
    # @see http://docs.aws.amazon.com/goto/WebAPI/wafv2-2019-07-29/XssMatchStatement AWS API Documentation
    #
    class XssMatchStatement < Struct.new(
      :field_to_match,
      :text_transformations)
      SENSITIVE = []
      include Aws::Structure
    end

  end
end