Class WebACL
- All Implemented Interfaces:
Serializable
,SdkPojo
,ToCopyableBuilder<WebACL.Builder,
WebACL>
This is AWS WAF Classic documentation. For more information, see AWS WAF Classic in the developer guide.
For the latest version of AWS WAF, use the AWS WAFV2 API and see the AWS WAF Developer Guide. With the latest version, AWS WAF has a single set of endpoints for regional and global use.
Contains the Rules
that identify the requests that you want to allow, block, or count. In a
WebACL
, you also specify a default action (ALLOW
or BLOCK
), and the action for
each Rule
that you add to a WebACL
, for example, block requests from specified IP addresses
or block requests from specified referrers. You also associate the WebACL
with a CloudFront distribution
to identify the requests that you want AWS WAF to filter. If you add more than one Rule
to a
WebACL
, a request needs to match only one of the specifications to be allowed, blocked, or counted. For
more information, see UpdateWebACL.
- See Also:
-
Nested Class Summary
Nested Classes -
Method Summary
Modifier and TypeMethodDescriptionstatic WebACL.Builder
builder()
final WafAction
The action to perform if none of theRules
contained in theWebACL
match.final boolean
final boolean
equalsBySdkFields
(Object obj) Indicates whether some other object is "equal to" this one by SDK fields.final <T> Optional
<T> getValueForField
(String fieldName, Class<T> clazz) final int
hashCode()
final boolean
hasRules()
For responses, this returns true if the service returned a value for the Rules property.final String
A friendly name or description for the metrics for thisWebACL
.final String
name()
A friendly name or description of theWebACL
.final List
<ActivatedRule> rules()
An array that contains the action for eachRule
in aWebACL
, the priority of theRule
, and the ID of theRule
.static Class
<? extends WebACL.Builder> Take this object and create a builder that contains all of the current property values of this object.final String
toString()
Returns a string representation of this object.final String
Tha Amazon Resource Name (ARN) of the web ACL.final String
webACLId()
A unique identifier for aWebACL
.Methods inherited from interface software.amazon.awssdk.utils.builder.ToCopyableBuilder
copy
-
Method Details
-
webACLId
A unique identifier for a
WebACL
. You useWebACLId
to get information about aWebACL
(see GetWebACL), update aWebACL
(see UpdateWebACL), and delete aWebACL
from AWS WAF (see DeleteWebACL).WebACLId
is returned by CreateWebACL and by ListWebACLs.- Returns:
- A unique identifier for a
WebACL
. You useWebACLId
to get information about aWebACL
(see GetWebACL), update aWebACL
(see UpdateWebACL), and delete aWebACL
from AWS WAF (see DeleteWebACL).WebACLId
is returned by CreateWebACL and by ListWebACLs.
-
name
A friendly name or description of the
WebACL
. You can't change the name of aWebACL
after you create it.- Returns:
- A friendly name or description of the
WebACL
. You can't change the name of aWebACL
after you create it.
-
metricName
A friendly name or description for the metrics for this
WebACL
. The name can contain only alphanumeric characters (A-Z, a-z, 0-9), with maximum length 128 and minimum length one. It can't contain whitespace or metric names reserved for AWS WAF, including "All" and "Default_Action." You can't changeMetricName
after you create theWebACL
.- Returns:
- A friendly name or description for the metrics for this
WebACL
. The name can contain only alphanumeric characters (A-Z, a-z, 0-9), with maximum length 128 and minimum length one. It can't contain whitespace or metric names reserved for AWS WAF, including "All" and "Default_Action." You can't changeMetricName
after you create theWebACL
.
-
defaultAction
The action to perform if none of the
Rules
contained in theWebACL
match. The action is specified by the WafAction object.- Returns:
- The action to perform if none of the
Rules
contained in theWebACL
match. The action is specified by the WafAction object.
-
hasRules
public final boolean hasRules()For responses, this returns true if the service returned a value for the Rules property. This DOES NOT check that the value is non-empty (for which, you should check theisEmpty()
method on the property). This is useful because the SDK will never return a null collection or map, but you may need to differentiate between the service returning nothing (or null) and the service returning an empty collection or map. For requests, this returns true if a value for the property was specified in the request builder, and false if a value was not specified. -
rules
An array that contains the action for each
Rule
in aWebACL
, the priority of theRule
, and the ID of theRule
.Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
This method will never return null. If you would like to know whether the service returned this field (so that you can differentiate between null and empty), you can use the
hasRules()
method.- Returns:
- An array that contains the action for each
Rule
in aWebACL
, the priority of theRule
, and the ID of theRule
.
-
webACLArn
Tha Amazon Resource Name (ARN) of the web ACL.
- Returns:
- Tha Amazon Resource Name (ARN) of the web ACL.
-
toBuilder
Description copied from interface:ToCopyableBuilder
Take this object and create a builder that contains all of the current property values of this object.- Specified by:
toBuilder
in interfaceToCopyableBuilder<WebACL.Builder,
WebACL> - Returns:
- a builder for type T
-
builder
-
serializableBuilderClass
-
hashCode
public final int hashCode() -
equals
-
equalsBySdkFields
Description copied from interface:SdkPojo
Indicates whether some other object is "equal to" this one by SDK fields. An SDK field is a modeled, non-inherited field in anSdkPojo
class, and is generated based on a service model.If an
SdkPojo
class does not have any inherited fields,equalsBySdkFields
andequals
are essentially the same.- Specified by:
equalsBySdkFields
in interfaceSdkPojo
- Parameters:
obj
- the object to be compared with- Returns:
- true if the other object equals to this object by sdk fields, false otherwise.
-
toString
Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be redacted from this string using a placeholder value. -
getValueForField
-
sdkFields
-