-
Notifications
You must be signed in to change notification settings - Fork 165
/
aws_waf_rule_ordering.yml
135 lines (135 loc) · 4.33 KB
/
aws_waf_rule_ordering.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
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",
}