Detection rules › Panther
AWS WAF Rule Ordering
This policy validates that all WAF's have the correct rule ordering. Incorrect rule ordering could lead to less restrictive rules being matched and allowing traffic through before more restrictive rules that should have blocked the traffic.
Rule body yaml
AnalysisType: policy
Filename: aws_waf_rule_ordering.py
PolicyID: "AWS.WAF.RuleOrdering"
DisplayName: "AWS WAF Rule Ordering"
Enabled: false
ResourceTypes:
- AWS.WAF.Regional.WebACL
- AWS.WAF.WebACL
Tags:
- AWS
- Configuration Required
- Security Control
Severity: High
Description: >
This policy validates that all WAF's have the correct rule ordering. Incorrect rule ordering could lead to less restrictive rules being matched and allowing traffic through before more restrictive rules that should have blocked the traffic.
Runbook: >
https://docs.runpanther.io/alert-runbooks/built-in-policies/aws-waf-has-correct-rule-ordering
Reference: https://docs.aws.amazon.com/waf/latest/developerguide/web-acl-rules.html
Tests:
- Name: Web ACL Configured Properly
ExpectedResult: true
Resource:
{
"DefaultAction": { "Type": "ALLOW" },
"MetricName": "examplewebacl",
"Name": "example-web-acl",
"Rules":
[
{
"Action": { "Type": "BLOCK" },
"ExcludedRules": null,
"OverrideAction": null,
"Priority": 2,
"RuleId": "EXAMPLE_RULE_2_ID",
"Type": "REGULAR",
},
{
"Action": { "Type": "COUNT" },
"ExcludedRules": null,
"OverrideAction": null,
"Priority": 1,
"RuleId": "EXAMPLE_RULE_1_ID",
"Type": "REGULAR",
},
],
"WebACLArn": "arn:aws:waf-regional:us-west-2:123456789012:webacl/11112222-3333-4444",
"WebACLId": "EXAMPLE_WEB_ACL_ID",
}
- Name: Web ACL Has Incorrect Rules
ExpectedResult: false
Resource:
{
"DefaultAction": { "Type": "ALLOW" },
"MetricName": "examplewebacl",
"Name": "example-web-acl",
"Rules":
[
{
"Action": { "Type": "BLOCK" },
"ExcludedRules": null,
"OverrideAction": null,
"Priority": 2,
"RuleId": "111222-1111-2222-3333-111222333444",
"Type": "REGULAR",
},
{
"Action": { "Type": "COUNT" },
"ExcludedRules": null,
"OverrideAction": null,
"Priority": 1,
"RuleId": "111222-1111-1111-2222-111222333444",
"Type": "REGULAR",
},
],
"WebACLArn": "arn:aws:waf-regional:us-west-2:123456789012:webacl/11112222-3333-4444",
"WebACLId": "EXAMPLE_WEB_ACL_ID",
}
- Name: Web ACL Has Rules In Incorrect Order
ExpectedResult: false
Resource:
{
"DefaultAction": { "Type": "ALLOW" },
"MetricName": "examplewebacl",
"Name": "example-web-acl",
"Rules":
[
{
"Action": { "Type": "BLOCK" },
"ExcludedRules": null,
"OverrideAction": null,
"Priority": 2,
"RuleId": "EXAMPLE_RULE_1_ID",
"Type": "REGULAR",
},
{
"Action": { "Type": "COUNT" },
"ExcludedRules": null,
"OverrideAction": null,
"Priority": 1,
"RuleId": "EXAMPLE_RULE_2_ID",
"Type": "REGULAR",
},
],
"WebACLArn": "arn:aws:waf-regional:us-west-2:123456789012:webacl/11112222-3333-4444",
"WebACLId": "EXAMPLE_WEB_ACL_ID",
}
- Name: Web ACL Has No Ordering Configured
ExpectedResult: true
Resource:
{
"DefaultAction": { "Type": "ALLOW" },
"MetricName": "examplewebacl",
"Name": "example-web-acl",
"Rules":
[
{
"Action": { "Type": "BLOCK" },
"ExcludedRules": null,
"OverrideAction": null,
"Priority": 2,
"RuleId": "111222-1111-2222-3333-111222333444",
"Type": "REGULAR",
},
{
"Action": { "Type": "COUNT" },
"ExcludedRules": null,
"OverrideAction": null,
"Priority": 1,
"RuleId": "111222-1111-1111-2222-111222333444",
"Type": "REGULAR",
},
],
"WebACLArn": "arn:aws:waf-regional:us-west-2:123456789012:webacl/11112222-3333-4444",
"WebACLId": "11112222-3333-4444",
}
Detection logic
Condition
not not
This rule also runs imperative logic the parser cannot express as a filter; the conditions above are the structured part it could extract.
Exclusions
Top-level NOT(...) conjuncts: predicates this rule actively suppresses.
| Field | Kind | Excluded values |
|---|---|---|
WebACLId | eq | EXAMPLE_WEB_ACL_ID |
Indicators
Each row is a field, operator, and value that the rule matches. The corpus column counts how many other rules in the catalog look for the same combination: high numbers point to widely-used, community-vetted indicators. Blank or 1 shows that the indicator is specific to this rule.
| Field | Kind | Values |
|---|---|---|
WebACLId | in |
|