@aws-solutions-constructs/aws-wafwebacl-appsync 2.27.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,294 @@
1
+ "use strict";
2
+ /**
3
+ * Copyright 2022 Amazon.com, Inc. or its affiliates. All Rights Reserved.
4
+ *
5
+ * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance
6
+ * with the License. A copy of the License is located at
7
+ *
8
+ * http://www.apache.org/licenses/LICENSE-2.0
9
+ *
10
+ * or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES
11
+ * OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions
12
+ * and limitations under the License.
13
+ */
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ // Imports
16
+ const cdk = require("aws-cdk-lib");
17
+ const lib_1 = require("../lib");
18
+ const waf = require("aws-cdk-lib/aws-wafv2");
19
+ const defaults = require("@aws-solutions-constructs/core");
20
+ const appsync = require("aws-cdk-lib/aws-appsync");
21
+ require("@aws-cdk/assert/jest");
22
+ function deployAppsyncGraphqlApi(stack) {
23
+ return new appsync.CfnGraphQLApi(stack, "new-api", {
24
+ name: "api",
25
+ authenticationType: "API_KEY",
26
+ });
27
+ }
28
+ function deployConstruct(stack, webaclProps, existingWebaclObj) {
29
+ const api = deployAppsyncGraphqlApi(stack);
30
+ return new lib_1.WafwebaclToAppsync(stack, "test-waf-appsync", {
31
+ existingAppsyncApi: api,
32
+ webaclProps,
33
+ existingWebaclObj,
34
+ });
35
+ }
36
+ // --------------------------------------------------------------
37
+ // Test error handling for existing WAF web ACL and user provided web ACL props
38
+ // --------------------------------------------------------------
39
+ test("Test error handling for existing WAF web ACL and user provider web ACL props", () => {
40
+ const stack = new cdk.Stack();
41
+ const props = {
42
+ defaultAction: {
43
+ allow: {},
44
+ },
45
+ scope: "REGIONAL",
46
+ visibilityConfig: {
47
+ cloudWatchMetricsEnabled: false,
48
+ metricName: "webACL",
49
+ sampledRequestsEnabled: true,
50
+ },
51
+ };
52
+ const wafAcl = new waf.CfnWebACL(stack, "test-waf", props);
53
+ const api = deployAppsyncGraphqlApi(stack);
54
+ expect(() => {
55
+ new lib_1.WafwebaclToAppsync(stack, "test-waf-appsync", {
56
+ existingAppsyncApi: api,
57
+ existingWebaclObj: wafAcl,
58
+ webaclProps: props,
59
+ });
60
+ }).toThrowError();
61
+ });
62
+ // --------------------------------------------------------------
63
+ // Test default deployment
64
+ // --------------------------------------------------------------
65
+ test("Test default deployment", () => {
66
+ const stack = new cdk.Stack();
67
+ const construct = deployConstruct(stack);
68
+ expect(construct.webacl !== null);
69
+ expect(construct.appsyncApi !== null);
70
+ expect(stack).toHaveResource("AWS::WAFv2::WebACL", {
71
+ Rules: [
72
+ {
73
+ Name: "AWS-AWSManagedRulesBotControlRuleSet",
74
+ OverrideAction: {
75
+ None: {},
76
+ },
77
+ Priority: 0,
78
+ Statement: {
79
+ ManagedRuleGroupStatement: {
80
+ Name: "AWSManagedRulesBotControlRuleSet",
81
+ VendorName: "AWS",
82
+ },
83
+ },
84
+ VisibilityConfig: {
85
+ CloudWatchMetricsEnabled: true,
86
+ MetricName: "AWSManagedRulesBotControlRuleSet",
87
+ SampledRequestsEnabled: true,
88
+ },
89
+ },
90
+ {
91
+ Name: "AWS-AWSManagedRulesKnownBadInputsRuleSet",
92
+ OverrideAction: {
93
+ None: {},
94
+ },
95
+ Priority: 1,
96
+ Statement: {
97
+ ManagedRuleGroupStatement: {
98
+ Name: "AWSManagedRulesKnownBadInputsRuleSet",
99
+ VendorName: "AWS",
100
+ },
101
+ },
102
+ VisibilityConfig: {
103
+ CloudWatchMetricsEnabled: true,
104
+ MetricName: "AWSManagedRulesKnownBadInputsRuleSet",
105
+ SampledRequestsEnabled: true,
106
+ },
107
+ },
108
+ {
109
+ Name: "AWS-AWSManagedRulesCommonRuleSet",
110
+ OverrideAction: {
111
+ None: {},
112
+ },
113
+ Priority: 2,
114
+ Statement: {
115
+ ManagedRuleGroupStatement: {
116
+ Name: "AWSManagedRulesCommonRuleSet",
117
+ VendorName: "AWS",
118
+ },
119
+ },
120
+ VisibilityConfig: {
121
+ CloudWatchMetricsEnabled: true,
122
+ MetricName: "AWSManagedRulesCommonRuleSet",
123
+ SampledRequestsEnabled: true,
124
+ },
125
+ },
126
+ {
127
+ Name: "AWS-AWSManagedRulesAnonymousIpList",
128
+ OverrideAction: {
129
+ None: {},
130
+ },
131
+ Priority: 3,
132
+ Statement: {
133
+ ManagedRuleGroupStatement: {
134
+ Name: "AWSManagedRulesAnonymousIpList",
135
+ VendorName: "AWS",
136
+ },
137
+ },
138
+ VisibilityConfig: {
139
+ CloudWatchMetricsEnabled: true,
140
+ MetricName: "AWSManagedRulesAnonymousIpList",
141
+ SampledRequestsEnabled: true,
142
+ },
143
+ },
144
+ {
145
+ Name: "AWS-AWSManagedRulesAmazonIpReputationList",
146
+ OverrideAction: {
147
+ None: {},
148
+ },
149
+ Priority: 4,
150
+ Statement: {
151
+ ManagedRuleGroupStatement: {
152
+ Name: "AWSManagedRulesAmazonIpReputationList",
153
+ VendorName: "AWS",
154
+ },
155
+ },
156
+ VisibilityConfig: {
157
+ CloudWatchMetricsEnabled: true,
158
+ MetricName: "AWSManagedRulesAmazonIpReputationList",
159
+ SampledRequestsEnabled: true,
160
+ },
161
+ },
162
+ {
163
+ Name: "AWS-AWSManagedRulesAdminProtectionRuleSet",
164
+ OverrideAction: {
165
+ None: {},
166
+ },
167
+ Priority: 5,
168
+ Statement: {
169
+ ManagedRuleGroupStatement: {
170
+ Name: "AWSManagedRulesAdminProtectionRuleSet",
171
+ VendorName: "AWS",
172
+ },
173
+ },
174
+ VisibilityConfig: {
175
+ CloudWatchMetricsEnabled: true,
176
+ MetricName: "AWSManagedRulesAdminProtectionRuleSet",
177
+ SampledRequestsEnabled: true,
178
+ },
179
+ },
180
+ {
181
+ Name: "AWS-AWSManagedRulesSQLiRuleSet",
182
+ OverrideAction: {
183
+ None: {},
184
+ },
185
+ Priority: 6,
186
+ Statement: {
187
+ ManagedRuleGroupStatement: {
188
+ Name: "AWSManagedRulesSQLiRuleSet",
189
+ VendorName: "AWS",
190
+ },
191
+ },
192
+ VisibilityConfig: {
193
+ CloudWatchMetricsEnabled: true,
194
+ MetricName: "AWSManagedRulesSQLiRuleSet",
195
+ SampledRequestsEnabled: true,
196
+ },
197
+ },
198
+ ],
199
+ });
200
+ });
201
+ // --------------------------------------------------------------
202
+ // Test web acl with user provided acl props
203
+ // --------------------------------------------------------------
204
+ test("Test user provided acl props", () => {
205
+ const stack = new cdk.Stack();
206
+ const webaclProps = {
207
+ defaultAction: {
208
+ allow: {},
209
+ },
210
+ scope: "REGIONAL",
211
+ visibilityConfig: {
212
+ cloudWatchMetricsEnabled: false,
213
+ metricName: "webACL",
214
+ sampledRequestsEnabled: true,
215
+ },
216
+ rules: [
217
+ defaults.wrapManagedRuleSet("AWSManagedRulesCommonRuleSet", "AWS", 0),
218
+ defaults.wrapManagedRuleSet("AWSManagedRulesWordPressRuleSet", "AWS", 1),
219
+ ],
220
+ };
221
+ deployConstruct(stack, webaclProps);
222
+ expect(stack).toHaveResource("AWS::WAFv2::WebACL", {
223
+ VisibilityConfig: {
224
+ CloudWatchMetricsEnabled: false,
225
+ MetricName: "webACL",
226
+ SampledRequestsEnabled: true,
227
+ },
228
+ Rules: [
229
+ {
230
+ Name: "AWS-AWSManagedRulesCommonRuleSet",
231
+ OverrideAction: {
232
+ None: {},
233
+ },
234
+ Priority: 0,
235
+ Statement: {
236
+ ManagedRuleGroupStatement: {
237
+ Name: "AWSManagedRulesCommonRuleSet",
238
+ VendorName: "AWS",
239
+ },
240
+ },
241
+ VisibilityConfig: {
242
+ CloudWatchMetricsEnabled: true,
243
+ MetricName: "AWSManagedRulesCommonRuleSet",
244
+ SampledRequestsEnabled: true,
245
+ },
246
+ },
247
+ {
248
+ Name: "AWS-AWSManagedRulesWordPressRuleSet",
249
+ OverrideAction: {
250
+ None: {},
251
+ },
252
+ Priority: 1,
253
+ Statement: {
254
+ ManagedRuleGroupStatement: {
255
+ Name: "AWSManagedRulesWordPressRuleSet",
256
+ VendorName: "AWS",
257
+ },
258
+ },
259
+ VisibilityConfig: {
260
+ CloudWatchMetricsEnabled: true,
261
+ MetricName: "AWSManagedRulesWordPressRuleSet",
262
+ SampledRequestsEnabled: true,
263
+ },
264
+ },
265
+ ],
266
+ });
267
+ });
268
+ // --------------------------------------------------------------
269
+ // Test existing web ACL
270
+ // --------------------------------------------------------------
271
+ test("Test existing web ACL", () => {
272
+ const stack = new cdk.Stack();
273
+ const webacl = new waf.CfnWebACL(stack, "test-webacl", {
274
+ defaultAction: {
275
+ allow: {},
276
+ },
277
+ scope: "REGIONAL",
278
+ visibilityConfig: {
279
+ cloudWatchMetricsEnabled: true,
280
+ metricName: "webACL",
281
+ sampledRequestsEnabled: true,
282
+ },
283
+ });
284
+ deployConstruct(stack, undefined, webacl);
285
+ expect(stack).toHaveResource("AWS::WAFv2::WebACL", {
286
+ VisibilityConfig: {
287
+ CloudWatchMetricsEnabled: true,
288
+ MetricName: "webACL",
289
+ SampledRequestsEnabled: true,
290
+ },
291
+ });
292
+ expect(stack).toCountResources("AWS::WAFv2::WebACL", 1);
293
+ });
294
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.wafwebacl-appsync.test.js","sourceRoot":"","sources":["test.wafwebacl-appsync.test.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n *  Copyright 2022 Amazon.com, Inc. or its affiliates. All Rights Reserved.\n *\n *  Licensed under the Apache License, Version 2.0 (the \"License\"). You may not use this file except in compliance\n *  with the License. A copy of the License is located at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n *  or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES\n *  OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions\n *  and limitations under the License.\n */\n\n// Imports\nimport * as cdk from \"aws-cdk-lib\";\nimport { WafwebaclToAppsync } from \"../lib\";\nimport * as waf from \"aws-cdk-lib/aws-wafv2\";\nimport * as defaults from \"@aws-solutions-constructs/core\";\nimport * as appsync from \"aws-cdk-lib/aws-appsync\";\nimport \"@aws-cdk/assert/jest\";\n\nfunction deployAppsyncGraphqlApi(stack: cdk.Stack) {\n  return new appsync.CfnGraphQLApi(stack, \"new-api\", {\n    name: \"api\",\n    authenticationType: \"API_KEY\",\n  });\n}\n\nfunction deployConstruct(\n  stack: cdk.Stack,\n  webaclProps?: waf.CfnWebACLProps,\n  existingWebaclObj?: waf.CfnWebACL\n) {\n  const api = deployAppsyncGraphqlApi(stack);\n\n  return new WafwebaclToAppsync(stack, \"test-waf-appsync\", {\n    existingAppsyncApi: api,\n    webaclProps,\n    existingWebaclObj,\n  });\n}\n\n// --------------------------------------------------------------\n// Test error handling for existing WAF web ACL and user provided web ACL props\n// --------------------------------------------------------------\ntest(\"Test error handling for existing WAF web ACL and user provider web ACL props\", () => {\n  const stack = new cdk.Stack();\n  const props: waf.CfnWebACLProps = {\n    defaultAction: {\n      allow: {},\n    },\n    scope: \"REGIONAL\",\n    visibilityConfig: {\n      cloudWatchMetricsEnabled: false,\n      metricName: \"webACL\",\n      sampledRequestsEnabled: true,\n    },\n  };\n\n  const wafAcl = new waf.CfnWebACL(stack, \"test-waf\", props);\n  const api = deployAppsyncGraphqlApi(stack);\n\n  expect(() => {\n    new WafwebaclToAppsync(stack, \"test-waf-appsync\", {\n      existingAppsyncApi: api,\n      existingWebaclObj: wafAcl,\n      webaclProps: props,\n    });\n  }).toThrowError();\n});\n\n// --------------------------------------------------------------\n// Test default deployment\n// --------------------------------------------------------------\ntest(\"Test default deployment\", () => {\n  const stack = new cdk.Stack();\n  const construct = deployConstruct(stack);\n\n  expect(construct.webacl !== null);\n  expect(construct.appsyncApi !== null);\n\n  expect(stack).toHaveResource(\"AWS::WAFv2::WebACL\", {\n    Rules: [\n      {\n        Name: \"AWS-AWSManagedRulesBotControlRuleSet\",\n        OverrideAction: {\n          None: {},\n        },\n        Priority: 0,\n        Statement: {\n          ManagedRuleGroupStatement: {\n            Name: \"AWSManagedRulesBotControlRuleSet\",\n            VendorName: \"AWS\",\n          },\n        },\n        VisibilityConfig: {\n          CloudWatchMetricsEnabled: true,\n          MetricName: \"AWSManagedRulesBotControlRuleSet\",\n          SampledRequestsEnabled: true,\n        },\n      },\n      {\n        Name: \"AWS-AWSManagedRulesKnownBadInputsRuleSet\",\n        OverrideAction: {\n          None: {},\n        },\n        Priority: 1,\n        Statement: {\n          ManagedRuleGroupStatement: {\n            Name: \"AWSManagedRulesKnownBadInputsRuleSet\",\n            VendorName: \"AWS\",\n          },\n        },\n        VisibilityConfig: {\n          CloudWatchMetricsEnabled: true,\n          MetricName: \"AWSManagedRulesKnownBadInputsRuleSet\",\n          SampledRequestsEnabled: true,\n        },\n      },\n      {\n        Name: \"AWS-AWSManagedRulesCommonRuleSet\",\n        OverrideAction: {\n          None: {},\n        },\n        Priority: 2,\n        Statement: {\n          ManagedRuleGroupStatement: {\n            Name: \"AWSManagedRulesCommonRuleSet\",\n            VendorName: \"AWS\",\n          },\n        },\n        VisibilityConfig: {\n          CloudWatchMetricsEnabled: true,\n          MetricName: \"AWSManagedRulesCommonRuleSet\",\n          SampledRequestsEnabled: true,\n        },\n      },\n      {\n        Name: \"AWS-AWSManagedRulesAnonymousIpList\",\n        OverrideAction: {\n          None: {},\n        },\n        Priority: 3,\n        Statement: {\n          ManagedRuleGroupStatement: {\n            Name: \"AWSManagedRulesAnonymousIpList\",\n            VendorName: \"AWS\",\n          },\n        },\n        VisibilityConfig: {\n          CloudWatchMetricsEnabled: true,\n          MetricName: \"AWSManagedRulesAnonymousIpList\",\n          SampledRequestsEnabled: true,\n        },\n      },\n      {\n        Name: \"AWS-AWSManagedRulesAmazonIpReputationList\",\n        OverrideAction: {\n          None: {},\n        },\n        Priority: 4,\n        Statement: {\n          ManagedRuleGroupStatement: {\n            Name: \"AWSManagedRulesAmazonIpReputationList\",\n            VendorName: \"AWS\",\n          },\n        },\n        VisibilityConfig: {\n          CloudWatchMetricsEnabled: true,\n          MetricName: \"AWSManagedRulesAmazonIpReputationList\",\n          SampledRequestsEnabled: true,\n        },\n      },\n      {\n        Name: \"AWS-AWSManagedRulesAdminProtectionRuleSet\",\n        OverrideAction: {\n          None: {},\n        },\n        Priority: 5,\n        Statement: {\n          ManagedRuleGroupStatement: {\n            Name: \"AWSManagedRulesAdminProtectionRuleSet\",\n            VendorName: \"AWS\",\n          },\n        },\n        VisibilityConfig: {\n          CloudWatchMetricsEnabled: true,\n          MetricName: \"AWSManagedRulesAdminProtectionRuleSet\",\n          SampledRequestsEnabled: true,\n        },\n      },\n      {\n        Name: \"AWS-AWSManagedRulesSQLiRuleSet\",\n        OverrideAction: {\n          None: {},\n        },\n        Priority: 6,\n        Statement: {\n          ManagedRuleGroupStatement: {\n            Name: \"AWSManagedRulesSQLiRuleSet\",\n            VendorName: \"AWS\",\n          },\n        },\n        VisibilityConfig: {\n          CloudWatchMetricsEnabled: true,\n          MetricName: \"AWSManagedRulesSQLiRuleSet\",\n          SampledRequestsEnabled: true,\n        },\n      },\n    ],\n  });\n});\n\n// --------------------------------------------------------------\n// Test web acl with user provided acl props\n// --------------------------------------------------------------\ntest(\"Test user provided acl props\", () => {\n  const stack = new cdk.Stack();\n  const webaclProps: waf.CfnWebACLProps = {\n    defaultAction: {\n      allow: {},\n    },\n    scope: \"REGIONAL\",\n    visibilityConfig: {\n      cloudWatchMetricsEnabled: false,\n      metricName: \"webACL\",\n      sampledRequestsEnabled: true,\n    },\n    rules: [\n      defaults.wrapManagedRuleSet(\"AWSManagedRulesCommonRuleSet\", \"AWS\", 0),\n      defaults.wrapManagedRuleSet(\"AWSManagedRulesWordPressRuleSet\", \"AWS\", 1),\n    ],\n  };\n\n  deployConstruct(stack, webaclProps);\n\n  expect(stack).toHaveResource(\"AWS::WAFv2::WebACL\", {\n    VisibilityConfig: {\n      CloudWatchMetricsEnabled: false,\n      MetricName: \"webACL\",\n      SampledRequestsEnabled: true,\n    },\n    Rules: [\n      {\n        Name: \"AWS-AWSManagedRulesCommonRuleSet\",\n        OverrideAction: {\n          None: {},\n        },\n        Priority: 0,\n        Statement: {\n          ManagedRuleGroupStatement: {\n            Name: \"AWSManagedRulesCommonRuleSet\",\n            VendorName: \"AWS\",\n          },\n        },\n        VisibilityConfig: {\n          CloudWatchMetricsEnabled: true,\n          MetricName: \"AWSManagedRulesCommonRuleSet\",\n          SampledRequestsEnabled: true,\n        },\n      },\n      {\n        Name: \"AWS-AWSManagedRulesWordPressRuleSet\",\n        OverrideAction: {\n          None: {},\n        },\n        Priority: 1,\n        Statement: {\n          ManagedRuleGroupStatement: {\n            Name: \"AWSManagedRulesWordPressRuleSet\",\n            VendorName: \"AWS\",\n          },\n        },\n        VisibilityConfig: {\n          CloudWatchMetricsEnabled: true,\n          MetricName: \"AWSManagedRulesWordPressRuleSet\",\n          SampledRequestsEnabled: true,\n        },\n      },\n    ],\n  });\n});\n\n// --------------------------------------------------------------\n// Test existing web ACL\n// --------------------------------------------------------------\ntest(\"Test existing web ACL\", () => {\n  const stack = new cdk.Stack();\n  const webacl: waf.CfnWebACL = new waf.CfnWebACL(stack, \"test-webacl\", {\n    defaultAction: {\n      allow: {},\n    },\n    scope: \"REGIONAL\",\n    visibilityConfig: {\n      cloudWatchMetricsEnabled: true,\n      metricName: \"webACL\",\n      sampledRequestsEnabled: true,\n    },\n  });\n\n  deployConstruct(stack, undefined, webacl);\n\n  expect(stack).toHaveResource(\"AWS::WAFv2::WebACL\", {\n    VisibilityConfig: {\n      CloudWatchMetricsEnabled: true,\n      MetricName: \"webACL\",\n      SampledRequestsEnabled: true,\n    },\n  });\n\n  expect(stack).toCountResources(\"AWS::WAFv2::WebACL\", 1);\n});\n"]}