@aws-solutions-constructs/aws-wafwebacl-appsync 2.98.0 → 2.100.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.
package/.jsii CHANGED
@@ -8,8 +8,8 @@
8
8
  "url": "https://aws.amazon.com"
9
9
  },
10
10
  "dependencies": {
11
- "@aws-solutions-constructs/core": "2.98.0",
12
- "aws-cdk-lib": "^2.234.0",
11
+ "@aws-solutions-constructs/core": "2.100.0",
12
+ "aws-cdk-lib": "^2.239.0",
13
13
  "constructs": "^10.0.0"
14
14
  },
15
15
  "dependencyClosure": {
@@ -100,8 +100,7 @@
100
100
  "dotnet": {
101
101
  "iconUrl": "https://raw.githubusercontent.com/aws/aws-cdk/master/logo/default-256-dark.png",
102
102
  "namespace": "Amazon.SolutionsConstructs.AWS.Core",
103
- "packageId": "Amazon.SolutionsConstructs.AWS.Core",
104
- "signAssembly": true
103
+ "packageId": "Amazon.SolutionsConstructs.AWS.Core"
105
104
  },
106
105
  "java": {
107
106
  "maven": {
@@ -2631,6 +2630,19 @@
2631
2630
  }
2632
2631
  }
2633
2632
  },
2633
+ "aws-cdk-lib.aws_mwaaserverless": {
2634
+ "targets": {
2635
+ "dotnet": {
2636
+ "namespace": "Amazon.CDK.AWS.MWAAServerless"
2637
+ },
2638
+ "java": {
2639
+ "package": "software.amazon.awscdk.services.mwaaserverless"
2640
+ },
2641
+ "python": {
2642
+ "module": "aws_cdk.aws_mwaaserverless"
2643
+ }
2644
+ }
2645
+ },
2634
2646
  "aws-cdk-lib.aws_neptune": {
2635
2647
  "targets": {
2636
2648
  "dotnet": {
@@ -6836,6 +6848,22 @@
6836
6848
  }
6837
6849
  }
6838
6850
  },
6851
+ "aws-cdk-lib.interfaces.aws_mwaaserverless": {
6852
+ "targets": {
6853
+ "dotnet": {
6854
+ "namespace": "Amazon.CDK.Interfaces.MWAAServerless"
6855
+ },
6856
+ "go": {
6857
+ "packageName": "interfacesawsmwaaserverless"
6858
+ },
6859
+ "java": {
6860
+ "package": "software.amazon.awscdk.interfaces.mwaaserverless"
6861
+ },
6862
+ "python": {
6863
+ "module": "aws_cdk.interfaces.aws_mwaaserverless"
6864
+ }
6865
+ }
6866
+ },
6839
6867
  "aws-cdk-lib.interfaces.aws_neptune": {
6840
6868
  "targets": {
6841
6869
  "dotnet": {
@@ -8492,7 +8520,7 @@
8492
8520
  },
8493
8521
  "description": "CDK constructs for defining an AWS web WAF connected to an AWS AppSync API.",
8494
8522
  "homepage": "https://github.com/awslabs/aws-solutions-constructs.git",
8495
- "jsiiVersion": "5.9.8 (build 3d2e131)",
8523
+ "jsiiVersion": "5.9.28 (build cbad63d)",
8496
8524
  "keywords": [
8497
8525
  "aws",
8498
8526
  "cdk",
@@ -8524,8 +8552,7 @@
8524
8552
  "dotnet": {
8525
8553
  "iconUrl": "https://raw.githubusercontent.com/aws/aws-cdk/master/logo/default-256-dark.png",
8526
8554
  "namespace": "Amazon.SolutionsConstructs.AWS.WafwebaclAppsync",
8527
- "packageId": "Amazon.SolutionsConstructs.AWS.WafwebaclAppsync",
8528
- "signAssembly": true
8555
+ "packageId": "Amazon.SolutionsConstructs.AWS.WafwebaclAppsync"
8529
8556
  },
8530
8557
  "java": {
8531
8558
  "maven": {
@@ -8694,6 +8721,6 @@
8694
8721
  "symbolId": "lib/index:WafwebaclToAppsyncProps"
8695
8722
  }
8696
8723
  },
8697
- "version": "2.98.0",
8698
- "fingerprint": "AXGF1esnDy2YdcHZb/yXyonMbxTTUJxbArz8Sl+S3qQ="
8724
+ "version": "2.100.0",
8725
+ "fingerprint": "wZAhF+Dd5pa2etWAFosocxhgkoNrN+GJ2L5J52/s7+4="
8699
8726
  }
package/lib/index.js CHANGED
@@ -34,6 +34,7 @@ class WafwebaclToAppsync extends constructs_1.Construct {
34
34
  constructor(scope, id, props) {
35
35
  super(scope, id);
36
36
  defaults.CheckWafWebAclProps(props);
37
+ defaults.ValidateCfnWebACLProps(this, props.webaclProps);
37
38
  // Build the Web ACL
38
39
  this.webacl = defaults.buildWebacl(this, "REGIONAL", {
39
40
  existingWebaclObj: props.existingWebaclObj,
@@ -51,5 +52,5 @@ class WafwebaclToAppsync extends constructs_1.Construct {
51
52
  }
52
53
  exports.WafwebaclToAppsync = WafwebaclToAppsync;
53
54
  _a = JSII_RTTI_SYMBOL_1;
54
- WafwebaclToAppsync[_a] = { fqn: "@aws-solutions-constructs/aws-wafwebacl-appsync.WafwebaclToAppsync", version: "2.98.0" };
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBOzs7Ozs7Ozs7OztHQVdHO0FBRUgsVUFBVTtBQUNWLDZDQUE2QztBQUU3QywyREFBMkQ7QUFDM0Qsd0ZBQXdGO0FBQ3hGLDJDQUF1QztBQXlCdkM7O0dBRUc7QUFDSCxNQUFhLGtCQUFtQixTQUFRLHNCQUFTO0lBRy9DOzs7Ozs7T0FNRztJQUNILFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBOEI7UUFDdEUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNqQixRQUFRLENBQUMsbUJBQW1CLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFcEMsb0JBQW9CO1FBQ3BCLElBQUksQ0FBQyxNQUFNLEdBQUcsUUFBUSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsVUFBVSxFQUFFO1lBQ25ELGlCQUFpQixFQUFFLEtBQUssQ0FBQyxpQkFBaUI7WUFDMUMsV0FBVyxFQUFFLEtBQUssQ0FBQyxXQUFXO1NBQy9CLENBQUMsQ0FBQztRQUVILE1BQU0sZ0JBQWdCLEdBQUcsR0FBRyxFQUFFLG9CQUFvQixDQUFDO1FBQ25ELE1BQU0sbUJBQW1CLEdBQWtDO1lBQ3pELFNBQVMsRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU87WUFDOUIsV0FBVyxFQUFFLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxPQUFPO1NBQzlDLENBQUM7UUFFRiw2RUFBNkU7UUFDN0UsSUFBSSxHQUFHLENBQUMsb0JBQW9CLENBQUMsS0FBSyxFQUFFLGdCQUFnQixFQUFFLG1CQUFtQixDQUFDLENBQUMsQ0FBQyxVQUFVO1FBRXRGLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDLGtCQUFrQixDQUFDO0lBQzdDLENBQUM7O0FBOUJILGdEQStCQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogIENvcHlyaWdodCBBbWF6b24uY29tLCBJbmMuIG9yIGl0cyBhZmZpbGlhdGVzLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqICBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlXCIpLiBZb3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlXG4gKiAgd2l0aCB0aGUgTGljZW5zZS4gQSBjb3B5IG9mIHRoZSBMaWNlbnNlIGlzIGxvY2F0ZWQgYXRcbiAqXG4gKiAgICAgIGh0dHA6Ly93d3cuYXBhY2hlLm9yZy9saWNlbnNlcy9MSUNFTlNFLTIuMFxuICpcbiAqICBvciBpbiB0aGUgJ2xpY2Vuc2UnIGZpbGUgYWNjb21wYW55aW5nIHRoaXMgZmlsZS4gVGhpcyBmaWxlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuICdBUyBJUycgQkFTSVMsIFdJVEhPVVQgV0FSUkFOVElFU1xuICogIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGV4cHJlc3Mgb3IgaW1wbGllZC4gU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zXG4gKiAgYW5kIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5cbi8vIEltcG9ydHNcbmltcG9ydCAqIGFzIHdhZiBmcm9tIFwiYXdzLWNkay1saWIvYXdzLXdhZnYyXCI7XG5pbXBvcnQgKiBhcyBhcHBzeW5jIGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtYXBwc3luY1wiO1xuaW1wb3J0ICogYXMgZGVmYXVsdHMgZnJvbSBcIkBhd3Mtc29sdXRpb25zLWNvbnN0cnVjdHMvY29yZVwiO1xuLy8gTm90ZTogVG8gZW5zdXJlIENES3YyIGNvbXBhdGliaWxpdHksIGtlZXAgdGhlIGltcG9ydCBzdGF0ZW1lbnQgZm9yIENvbnN0cnVjdCBzZXBhcmF0ZVxuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHNcIjtcblxuLyoqXG4gKiBAc3VtbWFyeSBUaGUgcHJvcGVydGllcyBmb3IgdGhlIFdhZndlYmFjbFRvQXBwc3luYyBjbGFzcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBXYWZ3ZWJhY2xUb0FwcHN5bmNQcm9wcyB7XG4gIC8qKlxuICAgKiBUaGUgZXhpc3RpbmcgQXBwc3luYyBBUEkgdGhhdCB3aWxsIGJlIHByb3RlY3RlZCB3aXRoIHRoZSBXQUYgd2ViIEFDTC5cbiAgICovXG4gIHJlYWRvbmx5IGV4aXN0aW5nQXBwc3luY0FwaTogYXBwc3luYy5DZm5HcmFwaFFMQXBpO1xuICAvKipcbiAgICogT3B0aW9uYWwgLSBleGlzdGluZyBpbnN0YW5jZSBvZiBhIFdBRiB3ZWIgQUNMLCBwcm92aWRpbmcgYm90aCB0aGlzIGFuZCBgd2ViYWNsUHJvcHNgIGNhdXNlcyBhbiBlcnJvci5cbiAgICovXG4gIHJlYWRvbmx5IGV4aXN0aW5nV2ViYWNsT2JqPzogd2FmLkNmbldlYkFDTDtcbiAgLyoqXG4gICAqIE9wdGlvbmFsIHVzZXItcHJvdmlkZWQgcHJvcHMgdG8gb3ZlcnJpZGUgdGhlIGRlZmF1bHQgcHJvcHMgZm9yIHRoZSBBV1MgV0FGIHdlYiBBQ0wuIFByb3ZpZGluZyBib3RoIHRoaXMgYW5kXG4gICAqIGV4aXN0aW5nV2ViYWNsT2JqIGNhdXNlcyBhbiBlcnJvci4gVG8gdXNlIGEgZGlmZmVyZW50IGNvbGxlY3Rpb24gb2YgbWFuYWdlZCBydWxlIHNldHMsIHNwZWNpZnkgYSBuZXcgcnVsZXNcbiAgICogcHJvcGVydHkuIFVzZSBvdXIgbGluazouLi9jb3JlL2xpYi93YWYtZGVmYXVsdHMudHNbd3JhcE1hbmFnZWRSdWxlU2V0KG1hbmFnZWRHcm91cE5hbWU6IHN0cmluZywgdmVuZG9yTmFtZTpcbiAgICogc3RyaW5nLCBwcmlvcml0eTogbnVtYmVyKV0gZnVuY3Rpb24gZnJvbSBjb3JlIHRvIGNyZWF0ZSBhbiBhcnJheSBlbnRyeSBmcm9tIGVhY2ggZGVzaXJlZCBtYW5hZ2VkIHJ1bGUgc2V0LlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIERlZmF1bHQgcHJvcGVydGllcyBhcmUgdXNlZC5cbiAgICovXG4gIHJlYWRvbmx5IHdlYmFjbFByb3BzPzogd2FmLkNmbldlYkFDTFByb3BzIHwgYW55O1xufVxuXG4vKipcbiAqIEBzdW1tYXJ5IFRoZSBXYWZ3ZWJhY2xUb0FwcHN5bmMgY2xhc3MuXG4gKi9cbmV4cG9ydCBjbGFzcyBXYWZ3ZWJhY2xUb0FwcHN5bmMgZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuICBwdWJsaWMgcmVhZG9ubHkgd2ViYWNsOiB3YWYuQ2ZuV2ViQUNMO1xuICBwdWJsaWMgcmVhZG9ubHkgYXBwc3luY0FwaTogYXBwc3luYy5DZm5HcmFwaFFMQXBpO1xuICAvKipcbiAgICogQHN1bW1hcnkgQ29uc3RydWN0cyBhIG5ldyBpbnN0YW5jZSBvZiB0aGUgV2Fmd2ViYWNsVG9BcHBzeW5jIGNsYXNzLlxuICAgKiBAcGFyYW0ge2Nkay5BcHB9IHNjb3BlIC0gcmVwcmVzZW50cyB0aGUgc2NvcGUgZm9yIGFsbCB0aGUgcmVzb3VyY2VzLlxuICAgKiBAcGFyYW0ge3N0cmluZ30gaWQgLSB0aGlzIGlzIGEgYSBzY29wZS11bmlxdWUgaWQuXG4gICAqIEBwYXJhbSB7V2Fmd2ViYWNsVG9BcHBzeW5jUHJvcHN9IHByb3BzIC0gdXNlciBwcm92aWRlZCBwcm9wcyBmb3IgdGhlIGNvbnN0cnVjdC5cbiAgICogQGFjY2VzcyBwdWJsaWNcbiAgICovXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBXYWZ3ZWJhY2xUb0FwcHN5bmNQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG4gICAgZGVmYXVsdHMuQ2hlY2tXYWZXZWJBY2xQcm9wcyhwcm9wcyk7XG5cbiAgICAvLyBCdWlsZCB0aGUgV2ViIEFDTFxuICAgIHRoaXMud2ViYWNsID0gZGVmYXVsdHMuYnVpbGRXZWJhY2wodGhpcywgXCJSRUdJT05BTFwiLCB7XG4gICAgICBleGlzdGluZ1dlYmFjbE9iajogcHJvcHMuZXhpc3RpbmdXZWJhY2xPYmosXG4gICAgICB3ZWJhY2xQcm9wczogcHJvcHMud2ViYWNsUHJvcHMsXG4gICAgfSk7XG5cbiAgICBjb25zdCBhY2xBc3NvY2lhdGlvbklkID0gYCR7aWR9LVdlYkFDTEFzc29jaWF0aW9uYDtcbiAgICBjb25zdCBhY2xBc3NvY2lhdGlvblByb3BzOiB3YWYuQ2ZuV2ViQUNMQXNzb2NpYXRpb25Qcm9wcyA9IHtcbiAgICAgIHdlYkFjbEFybjogdGhpcy53ZWJhY2wuYXR0ckFybixcbiAgICAgIHJlc291cmNlQXJuOiBwcm9wcy5leGlzdGluZ0FwcHN5bmNBcGkuYXR0ckFybixcbiAgICB9O1xuXG4gICAgLy8gQmVmb3JlIHR1cm5pbmcgb2ZmIFNvbmFyUXViZSBmb3IgdGhlIGxpbmUsIHJlZHVjZSB0aGUgbGluZSB0byBpdCdzIG1pbmltdW1cbiAgICBuZXcgd2FmLkNmbldlYkFDTEFzc29jaWF0aW9uKHNjb3BlLCBhY2xBc3NvY2lhdGlvbklkLCBhY2xBc3NvY2lhdGlvblByb3BzKTsgLy8gTk9TT05BUlxuXG4gICAgdGhpcy5hcHBzeW5jQXBpID0gcHJvcHMuZXhpc3RpbmdBcHBzeW5jQXBpO1xuICB9XG59XG4iXX0=
55
+ WafwebaclToAppsync[_a] = { fqn: "@aws-solutions-constructs/aws-wafwebacl-appsync.WafwebaclToAppsync", version: "2.100.0" };
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBOzs7Ozs7Ozs7OztHQVdHO0FBRUgsVUFBVTtBQUNWLDZDQUE2QztBQUU3QywyREFBMkQ7QUFDM0Qsd0ZBQXdGO0FBQ3hGLDJDQUF1QztBQXlCdkM7O0dBRUc7QUFDSCxNQUFhLGtCQUFtQixTQUFRLHNCQUFTO0lBRy9DOzs7Ozs7T0FNRztJQUNILFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBOEI7UUFDdEUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNqQixRQUFRLENBQUMsbUJBQW1CLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDcEMsUUFBUSxDQUFDLHNCQUFzQixDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsV0FBVyxDQUFDLENBQUM7UUFFekQsb0JBQW9CO1FBQ3BCLElBQUksQ0FBQyxNQUFNLEdBQUcsUUFBUSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsVUFBVSxFQUFFO1lBQ25ELGlCQUFpQixFQUFFLEtBQUssQ0FBQyxpQkFBaUI7WUFDMUMsV0FBVyxFQUFFLEtBQUssQ0FBQyxXQUFXO1NBQy9CLENBQUMsQ0FBQztRQUVILE1BQU0sZ0JBQWdCLEdBQUcsR0FBRyxFQUFFLG9CQUFvQixDQUFDO1FBQ25ELE1BQU0sbUJBQW1CLEdBQWtDO1lBQ3pELFNBQVMsRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU87WUFDOUIsV0FBVyxFQUFFLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxPQUFPO1NBQzlDLENBQUM7UUFFRiw2RUFBNkU7UUFDN0UsSUFBSSxHQUFHLENBQUMsb0JBQW9CLENBQUMsS0FBSyxFQUFFLGdCQUFnQixFQUFFLG1CQUFtQixDQUFDLENBQUMsQ0FBQyxVQUFVO1FBRXRGLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDLGtCQUFrQixDQUFDO0lBQzdDLENBQUM7O0FBL0JILGdEQWdDQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogIENvcHlyaWdodCBBbWF6b24uY29tLCBJbmMuIG9yIGl0cyBhZmZpbGlhdGVzLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqICBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlXCIpLiBZb3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlXG4gKiAgd2l0aCB0aGUgTGljZW5zZS4gQSBjb3B5IG9mIHRoZSBMaWNlbnNlIGlzIGxvY2F0ZWQgYXRcbiAqXG4gKiAgICAgIGh0dHA6Ly93d3cuYXBhY2hlLm9yZy9saWNlbnNlcy9MSUNFTlNFLTIuMFxuICpcbiAqICBvciBpbiB0aGUgJ2xpY2Vuc2UnIGZpbGUgYWNjb21wYW55aW5nIHRoaXMgZmlsZS4gVGhpcyBmaWxlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuICdBUyBJUycgQkFTSVMsIFdJVEhPVVQgV0FSUkFOVElFU1xuICogIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGV4cHJlc3Mgb3IgaW1wbGllZC4gU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zXG4gKiAgYW5kIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5cbi8vIEltcG9ydHNcbmltcG9ydCAqIGFzIHdhZiBmcm9tIFwiYXdzLWNkay1saWIvYXdzLXdhZnYyXCI7XG5pbXBvcnQgKiBhcyBhcHBzeW5jIGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtYXBwc3luY1wiO1xuaW1wb3J0ICogYXMgZGVmYXVsdHMgZnJvbSBcIkBhd3Mtc29sdXRpb25zLWNvbnN0cnVjdHMvY29yZVwiO1xuLy8gTm90ZTogVG8gZW5zdXJlIENES3YyIGNvbXBhdGliaWxpdHksIGtlZXAgdGhlIGltcG9ydCBzdGF0ZW1lbnQgZm9yIENvbnN0cnVjdCBzZXBhcmF0ZVxuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHNcIjtcblxuLyoqXG4gKiBAc3VtbWFyeSBUaGUgcHJvcGVydGllcyBmb3IgdGhlIFdhZndlYmFjbFRvQXBwc3luYyBjbGFzcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBXYWZ3ZWJhY2xUb0FwcHN5bmNQcm9wcyB7XG4gIC8qKlxuICAgKiBUaGUgZXhpc3RpbmcgQXBwc3luYyBBUEkgdGhhdCB3aWxsIGJlIHByb3RlY3RlZCB3aXRoIHRoZSBXQUYgd2ViIEFDTC5cbiAgICovXG4gIHJlYWRvbmx5IGV4aXN0aW5nQXBwc3luY0FwaTogYXBwc3luYy5DZm5HcmFwaFFMQXBpO1xuICAvKipcbiAgICogT3B0aW9uYWwgLSBleGlzdGluZyBpbnN0YW5jZSBvZiBhIFdBRiB3ZWIgQUNMLCBwcm92aWRpbmcgYm90aCB0aGlzIGFuZCBgd2ViYWNsUHJvcHNgIGNhdXNlcyBhbiBlcnJvci5cbiAgICovXG4gIHJlYWRvbmx5IGV4aXN0aW5nV2ViYWNsT2JqPzogd2FmLkNmbldlYkFDTDtcbiAgLyoqXG4gICAqIE9wdGlvbmFsIHVzZXItcHJvdmlkZWQgcHJvcHMgdG8gb3ZlcnJpZGUgdGhlIGRlZmF1bHQgcHJvcHMgZm9yIHRoZSBBV1MgV0FGIHdlYiBBQ0wuIFByb3ZpZGluZyBib3RoIHRoaXMgYW5kXG4gICAqIGV4aXN0aW5nV2ViYWNsT2JqIGNhdXNlcyBhbiBlcnJvci4gVG8gdXNlIGEgZGlmZmVyZW50IGNvbGxlY3Rpb24gb2YgbWFuYWdlZCBydWxlIHNldHMsIHNwZWNpZnkgYSBuZXcgcnVsZXNcbiAgICogcHJvcGVydHkuIFVzZSBvdXIgbGluazouLi9jb3JlL2xpYi93YWYtZGVmYXVsdHMudHNbd3JhcE1hbmFnZWRSdWxlU2V0KG1hbmFnZWRHcm91cE5hbWU6IHN0cmluZywgdmVuZG9yTmFtZTpcbiAgICogc3RyaW5nLCBwcmlvcml0eTogbnVtYmVyKV0gZnVuY3Rpb24gZnJvbSBjb3JlIHRvIGNyZWF0ZSBhbiBhcnJheSBlbnRyeSBmcm9tIGVhY2ggZGVzaXJlZCBtYW5hZ2VkIHJ1bGUgc2V0LlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIERlZmF1bHQgcHJvcGVydGllcyBhcmUgdXNlZC5cbiAgICovXG4gIHJlYWRvbmx5IHdlYmFjbFByb3BzPzogd2FmLkNmbldlYkFDTFByb3BzIHwgYW55O1xufVxuXG4vKipcbiAqIEBzdW1tYXJ5IFRoZSBXYWZ3ZWJhY2xUb0FwcHN5bmMgY2xhc3MuXG4gKi9cbmV4cG9ydCBjbGFzcyBXYWZ3ZWJhY2xUb0FwcHN5bmMgZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuICBwdWJsaWMgcmVhZG9ubHkgd2ViYWNsOiB3YWYuQ2ZuV2ViQUNMO1xuICBwdWJsaWMgcmVhZG9ubHkgYXBwc3luY0FwaTogYXBwc3luYy5DZm5HcmFwaFFMQXBpO1xuICAvKipcbiAgICogQHN1bW1hcnkgQ29uc3RydWN0cyBhIG5ldyBpbnN0YW5jZSBvZiB0aGUgV2Fmd2ViYWNsVG9BcHBzeW5jIGNsYXNzLlxuICAgKiBAcGFyYW0ge2Nkay5BcHB9IHNjb3BlIC0gcmVwcmVzZW50cyB0aGUgc2NvcGUgZm9yIGFsbCB0aGUgcmVzb3VyY2VzLlxuICAgKiBAcGFyYW0ge3N0cmluZ30gaWQgLSB0aGlzIGlzIGEgYSBzY29wZS11bmlxdWUgaWQuXG4gICAqIEBwYXJhbSB7V2Fmd2ViYWNsVG9BcHBzeW5jUHJvcHN9IHByb3BzIC0gdXNlciBwcm92aWRlZCBwcm9wcyBmb3IgdGhlIGNvbnN0cnVjdC5cbiAgICogQGFjY2VzcyBwdWJsaWNcbiAgICovXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBXYWZ3ZWJhY2xUb0FwcHN5bmNQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG4gICAgZGVmYXVsdHMuQ2hlY2tXYWZXZWJBY2xQcm9wcyhwcm9wcyk7XG4gICAgZGVmYXVsdHMuVmFsaWRhdGVDZm5XZWJBQ0xQcm9wcyh0aGlzLCBwcm9wcy53ZWJhY2xQcm9wcyk7XG5cbiAgICAvLyBCdWlsZCB0aGUgV2ViIEFDTFxuICAgIHRoaXMud2ViYWNsID0gZGVmYXVsdHMuYnVpbGRXZWJhY2wodGhpcywgXCJSRUdJT05BTFwiLCB7XG4gICAgICBleGlzdGluZ1dlYmFjbE9iajogcHJvcHMuZXhpc3RpbmdXZWJhY2xPYmosXG4gICAgICB3ZWJhY2xQcm9wczogcHJvcHMud2ViYWNsUHJvcHMsXG4gICAgfSk7XG5cbiAgICBjb25zdCBhY2xBc3NvY2lhdGlvbklkID0gYCR7aWR9LVdlYkFDTEFzc29jaWF0aW9uYDtcbiAgICBjb25zdCBhY2xBc3NvY2lhdGlvblByb3BzOiB3YWYuQ2ZuV2ViQUNMQXNzb2NpYXRpb25Qcm9wcyA9IHtcbiAgICAgIHdlYkFjbEFybjogdGhpcy53ZWJhY2wuYXR0ckFybixcbiAgICAgIHJlc291cmNlQXJuOiBwcm9wcy5leGlzdGluZ0FwcHN5bmNBcGkuYXR0ckFybixcbiAgICB9O1xuXG4gICAgLy8gQmVmb3JlIHR1cm5pbmcgb2ZmIFNvbmFyUXViZSBmb3IgdGhlIGxpbmUsIHJlZHVjZSB0aGUgbGluZSB0byBpdCdzIG1pbmltdW1cbiAgICBuZXcgd2FmLkNmbldlYkFDTEFzc29jaWF0aW9uKHNjb3BlLCBhY2xBc3NvY2lhdGlvbklkLCBhY2xBc3NvY2lhdGlvblByb3BzKTsgLy8gTk9TT05BUlxuXG4gICAgdGhpcy5hcHBzeW5jQXBpID0gcHJvcHMuZXhpc3RpbmdBcHBzeW5jQXBpO1xuICB9XG59XG4iXX0=
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aws-solutions-constructs/aws-wafwebacl-appsync",
3
- "version": "2.98.0",
3
+ "version": "2.100.0",
4
4
  "description": "CDK constructs for defining an AWS web WAF connected to an AWS AppSync API.",
5
5
  "main": "lib/index.js",
6
6
  "types": "lib/index.d.ts",
@@ -45,7 +45,6 @@
45
45
  "dotnet": {
46
46
  "namespace": "Amazon.SolutionsConstructs.AWS.WafwebaclAppsync",
47
47
  "packageId": "Amazon.SolutionsConstructs.AWS.WafwebaclAppsync",
48
- "signAssembly": true,
49
48
  "iconUrl": "https://raw.githubusercontent.com/aws/aws-cdk/master/logo/default-256-dark.png"
50
49
  },
51
50
  "python": {
@@ -55,13 +54,13 @@
55
54
  }
56
55
  },
57
56
  "dependencies": {
58
- "@aws-solutions-constructs/core": "2.98.0",
57
+ "@aws-solutions-constructs/core": "2.100.0",
59
58
  "constructs": "^10.0.0"
60
59
  },
61
60
  "devDependencies": {
62
- "@aws-cdk/integ-tests-alpha": "2.234.0-alpha.0",
61
+ "@aws-cdk/integ-tests-alpha": "2.239.0-alpha.0",
63
62
  "@types/node": "^10.3.0",
64
- "aws-cdk-lib": "2.234.0",
63
+ "aws-cdk-lib": "2.239.0",
65
64
  "constructs": "^10.0.0"
66
65
  },
67
66
  "jest": {
@@ -79,8 +78,8 @@
79
78
  ]
80
79
  },
81
80
  "peerDependencies": {
82
- "@aws-solutions-constructs/core": "2.98.0",
83
- "aws-cdk-lib": "^2.234.0",
81
+ "@aws-solutions-constructs/core": "2.100.0",
82
+ "aws-cdk-lib": "^2.239.0",
84
83
  "constructs": "^10.0.0"
85
84
  },
86
85
  "keywords": [
@@ -0,0 +1,316 @@
1
+ "use strict";
2
+ /**
3
+ * Copyright 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
+ const assertions_1 = require("aws-cdk-lib/assertions");
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
+ test('Confirm CheckWafWebAclProps is called', () => {
37
+ const stack = new cdk.Stack();
38
+ const props = {
39
+ defaultAction: {
40
+ allow: {},
41
+ },
42
+ scope: "REGIONAL",
43
+ visibilityConfig: {
44
+ cloudWatchMetricsEnabled: false,
45
+ metricName: "webACL",
46
+ sampledRequestsEnabled: true,
47
+ },
48
+ };
49
+ const wafAcl = new waf.CfnWebACL(stack, "test-waf", props);
50
+ const api = deployAppsyncGraphqlApi(stack);
51
+ expect(() => {
52
+ new lib_1.WafwebaclToAppsync(stack, "test-waf-appsync", {
53
+ existingAppsyncApi: api,
54
+ existingWebaclObj: wafAcl,
55
+ webaclProps: props,
56
+ });
57
+ }).toThrow('Error - Either provide existingWebaclObj or webaclProps, but not both.\n');
58
+ });
59
+ // --------------------------------------------------------------
60
+ // Test default deployment
61
+ // --------------------------------------------------------------
62
+ test("Test default deployment", () => {
63
+ const stack = new cdk.Stack();
64
+ const construct = deployConstruct(stack);
65
+ expect(construct.webacl).toBeDefined();
66
+ expect(construct.appsyncApi).toBeDefined();
67
+ const template = assertions_1.Template.fromStack(stack);
68
+ template.hasResourceProperties("AWS::WAFv2::WebACL", {
69
+ Rules: [
70
+ {
71
+ Name: "AWS-AWSManagedRulesBotControlRuleSet",
72
+ OverrideAction: {
73
+ None: {},
74
+ },
75
+ Priority: 0,
76
+ Statement: {
77
+ ManagedRuleGroupStatement: {
78
+ Name: "AWSManagedRulesBotControlRuleSet",
79
+ VendorName: "AWS",
80
+ },
81
+ },
82
+ VisibilityConfig: {
83
+ CloudWatchMetricsEnabled: true,
84
+ MetricName: "AWSManagedRulesBotControlRuleSet",
85
+ SampledRequestsEnabled: true,
86
+ },
87
+ },
88
+ {
89
+ Name: "AWS-AWSManagedRulesKnownBadInputsRuleSet",
90
+ OverrideAction: {
91
+ None: {},
92
+ },
93
+ Priority: 1,
94
+ Statement: {
95
+ ManagedRuleGroupStatement: {
96
+ Name: "AWSManagedRulesKnownBadInputsRuleSet",
97
+ VendorName: "AWS",
98
+ },
99
+ },
100
+ VisibilityConfig: {
101
+ CloudWatchMetricsEnabled: true,
102
+ MetricName: "AWSManagedRulesKnownBadInputsRuleSet",
103
+ SampledRequestsEnabled: true,
104
+ },
105
+ },
106
+ {
107
+ Name: "AWS-AWSManagedRulesCommonRuleSet",
108
+ OverrideAction: {
109
+ None: {},
110
+ },
111
+ Priority: 2,
112
+ Statement: {
113
+ ManagedRuleGroupStatement: {
114
+ Name: "AWSManagedRulesCommonRuleSet",
115
+ VendorName: "AWS",
116
+ },
117
+ },
118
+ VisibilityConfig: {
119
+ CloudWatchMetricsEnabled: true,
120
+ MetricName: "AWSManagedRulesCommonRuleSet",
121
+ SampledRequestsEnabled: true,
122
+ },
123
+ },
124
+ {
125
+ Name: "AWS-AWSManagedRulesAnonymousIpList",
126
+ OverrideAction: {
127
+ None: {},
128
+ },
129
+ Priority: 3,
130
+ Statement: {
131
+ ManagedRuleGroupStatement: {
132
+ Name: "AWSManagedRulesAnonymousIpList",
133
+ VendorName: "AWS",
134
+ },
135
+ },
136
+ VisibilityConfig: {
137
+ CloudWatchMetricsEnabled: true,
138
+ MetricName: "AWSManagedRulesAnonymousIpList",
139
+ SampledRequestsEnabled: true,
140
+ },
141
+ },
142
+ {
143
+ Name: "AWS-AWSManagedRulesAmazonIpReputationList",
144
+ OverrideAction: {
145
+ None: {},
146
+ },
147
+ Priority: 4,
148
+ Statement: {
149
+ ManagedRuleGroupStatement: {
150
+ Name: "AWSManagedRulesAmazonIpReputationList",
151
+ VendorName: "AWS",
152
+ },
153
+ },
154
+ VisibilityConfig: {
155
+ CloudWatchMetricsEnabled: true,
156
+ MetricName: "AWSManagedRulesAmazonIpReputationList",
157
+ SampledRequestsEnabled: true,
158
+ },
159
+ },
160
+ {
161
+ Name: "AWS-AWSManagedRulesAdminProtectionRuleSet",
162
+ OverrideAction: {
163
+ None: {},
164
+ },
165
+ Priority: 5,
166
+ Statement: {
167
+ ManagedRuleGroupStatement: {
168
+ Name: "AWSManagedRulesAdminProtectionRuleSet",
169
+ VendorName: "AWS",
170
+ },
171
+ },
172
+ VisibilityConfig: {
173
+ CloudWatchMetricsEnabled: true,
174
+ MetricName: "AWSManagedRulesAdminProtectionRuleSet",
175
+ SampledRequestsEnabled: true,
176
+ },
177
+ },
178
+ {
179
+ Name: "AWS-AWSManagedRulesSQLiRuleSet",
180
+ OverrideAction: {
181
+ None: {},
182
+ },
183
+ Priority: 6,
184
+ Statement: {
185
+ ManagedRuleGroupStatement: {
186
+ Name: "AWSManagedRulesSQLiRuleSet",
187
+ VendorName: "AWS",
188
+ },
189
+ },
190
+ VisibilityConfig: {
191
+ CloudWatchMetricsEnabled: true,
192
+ MetricName: "AWSManagedRulesSQLiRuleSet",
193
+ SampledRequestsEnabled: true,
194
+ },
195
+ },
196
+ ],
197
+ });
198
+ });
199
+ test("Test user provided acl props", () => {
200
+ const stack = new cdk.Stack();
201
+ const webaclProps = {
202
+ defaultAction: {
203
+ allow: {},
204
+ },
205
+ scope: "REGIONAL",
206
+ visibilityConfig: {
207
+ cloudWatchMetricsEnabled: false,
208
+ metricName: "webACL",
209
+ sampledRequestsEnabled: true,
210
+ },
211
+ rules: [
212
+ defaults.wrapManagedRuleSet("AWSManagedRulesCommonRuleSet", "AWS", 0),
213
+ defaults.wrapManagedRuleSet("AWSManagedRulesWordPressRuleSet", "AWS", 1),
214
+ ],
215
+ };
216
+ deployConstruct(stack, webaclProps);
217
+ const template = assertions_1.Template.fromStack(stack);
218
+ template.hasResourceProperties("AWS::WAFv2::WebACL", {
219
+ VisibilityConfig: {
220
+ CloudWatchMetricsEnabled: false,
221
+ MetricName: "webACL",
222
+ SampledRequestsEnabled: true,
223
+ },
224
+ Rules: [
225
+ {
226
+ Name: "AWS-AWSManagedRulesCommonRuleSet",
227
+ OverrideAction: {
228
+ None: {},
229
+ },
230
+ Priority: 0,
231
+ Statement: {
232
+ ManagedRuleGroupStatement: {
233
+ Name: "AWSManagedRulesCommonRuleSet",
234
+ VendorName: "AWS",
235
+ },
236
+ },
237
+ VisibilityConfig: {
238
+ CloudWatchMetricsEnabled: true,
239
+ MetricName: "AWSManagedRulesCommonRuleSet",
240
+ SampledRequestsEnabled: true,
241
+ },
242
+ },
243
+ {
244
+ Name: "AWS-AWSManagedRulesWordPressRuleSet",
245
+ OverrideAction: {
246
+ None: {},
247
+ },
248
+ Priority: 1,
249
+ Statement: {
250
+ ManagedRuleGroupStatement: {
251
+ Name: "AWSManagedRulesWordPressRuleSet",
252
+ VendorName: "AWS",
253
+ },
254
+ },
255
+ VisibilityConfig: {
256
+ CloudWatchMetricsEnabled: true,
257
+ MetricName: "AWSManagedRulesWordPressRuleSet",
258
+ SampledRequestsEnabled: true,
259
+ },
260
+ },
261
+ ],
262
+ });
263
+ });
264
+ test("Test user provided partial acl props", () => {
265
+ const stack = new cdk.Stack();
266
+ const testName = 'test-name';
267
+ const webaclProps = {
268
+ name: testName
269
+ };
270
+ deployConstruct(stack, webaclProps);
271
+ const template = assertions_1.Template.fromStack(stack);
272
+ template.hasResourceProperties("AWS::WAFv2::WebACL", {
273
+ Name: testName
274
+ });
275
+ });
276
+ // --------------------------------------------------------------
277
+ // Test existing web ACL
278
+ // --------------------------------------------------------------
279
+ test("Test existing web ACL", () => {
280
+ const stack = new cdk.Stack();
281
+ const webacl = new waf.CfnWebACL(stack, "test-webacl", {
282
+ defaultAction: {
283
+ allow: {},
284
+ },
285
+ scope: "REGIONAL",
286
+ visibilityConfig: {
287
+ cloudWatchMetricsEnabled: true,
288
+ metricName: "webACL",
289
+ sampledRequestsEnabled: true,
290
+ },
291
+ });
292
+ deployConstruct(stack, undefined, webacl);
293
+ const template = assertions_1.Template.fromStack(stack);
294
+ template.hasResourceProperties("AWS::WAFv2::WebACL", {
295
+ VisibilityConfig: {
296
+ CloudWatchMetricsEnabled: true,
297
+ MetricName: "webACL",
298
+ SampledRequestsEnabled: true,
299
+ },
300
+ });
301
+ template.resourceCountIs("AWS::WAFv2::WebACL", 1);
302
+ });
303
+ test('Test that ValidateCfnWebACLProps() is being called', () => {
304
+ const stack = new cdk.Stack();
305
+ const props = {
306
+ existingAppsyncApi: deployAppsyncGraphqlApi(stack),
307
+ webaclProps: {
308
+ invalidProperty: true
309
+ }
310
+ };
311
+ const app = () => {
312
+ new lib_1.WafwebaclToAppsync(stack, 'test-construct', props);
313
+ };
314
+ expect(app).toThrow(/ERROR - invalidProperty is not a valid property of CfnWebACLProps/);
315
+ });
316
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wafwebacl-appsync.test.js","sourceRoot":"","sources":["wafwebacl-appsync.test.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n *  Copyright 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, WafwebaclToAppsyncProps } 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 { Template } from \"aws-cdk-lib/assertions\";\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 | any,\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\ntest('Confirm CheckWafWebAclProps is called', () => {\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  }).toThrow('Error - Either provide existingWebaclObj or webaclProps, but not both.\\n');\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).toBeDefined();\n  expect(construct.appsyncApi).toBeDefined();\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"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\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  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"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\ntest(\"Test user provided partial acl props\", () => {\n  const stack = new cdk.Stack();\n  const testName = 'test-name';\n  const webaclProps = {\n    name: testName\n  };\n\n  deployConstruct(stack, webaclProps);\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::WAFv2::WebACL\", {\n    Name: testName\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  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::WAFv2::WebACL\", {\n    VisibilityConfig: {\n      CloudWatchMetricsEnabled: true,\n      MetricName: \"webACL\",\n      SampledRequestsEnabled: true,\n    },\n  });\n\n  template.resourceCountIs(\"AWS::WAFv2::WebACL\", 1);\n});\n\ntest('Test that ValidateCfnWebACLProps() is being called', () => {\n  const stack = new cdk.Stack();\n  const props: WafwebaclToAppsyncProps = {\n    existingAppsyncApi: deployAppsyncGraphqlApi(stack),\n    webaclProps: {\n      invalidProperty: true\n    }\n  };\n\n  const app = () => {\n    new WafwebaclToAppsync(stack, 'test-construct', props);\n  };\n\n  expect(app).toThrow(/ERROR - invalidProperty is not a valid property of CfnWebACLProps/);\n});\n"]}
@@ -1,303 +0,0 @@
1
- "use strict";
2
- /**
3
- * Copyright 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
- const assertions_1 = require("aws-cdk-lib/assertions");
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
- test('Confirm CheckWafWebAclProps is called', () => {
37
- const stack = new cdk.Stack();
38
- const props = {
39
- defaultAction: {
40
- allow: {},
41
- },
42
- scope: "REGIONAL",
43
- visibilityConfig: {
44
- cloudWatchMetricsEnabled: false,
45
- metricName: "webACL",
46
- sampledRequestsEnabled: true,
47
- },
48
- };
49
- const wafAcl = new waf.CfnWebACL(stack, "test-waf", props);
50
- const api = deployAppsyncGraphqlApi(stack);
51
- expect(() => {
52
- new lib_1.WafwebaclToAppsync(stack, "test-waf-appsync", {
53
- existingAppsyncApi: api,
54
- existingWebaclObj: wafAcl,
55
- webaclProps: props,
56
- });
57
- }).toThrowError('Error - Either provide existingWebaclObj or webaclProps, but not both.\n');
58
- });
59
- // --------------------------------------------------------------
60
- // Test default deployment
61
- // --------------------------------------------------------------
62
- test("Test default deployment", () => {
63
- const stack = new cdk.Stack();
64
- const construct = deployConstruct(stack);
65
- expect(construct.webacl).toBeDefined();
66
- expect(construct.appsyncApi).toBeDefined();
67
- const template = assertions_1.Template.fromStack(stack);
68
- template.hasResourceProperties("AWS::WAFv2::WebACL", {
69
- Rules: [
70
- {
71
- Name: "AWS-AWSManagedRulesBotControlRuleSet",
72
- OverrideAction: {
73
- None: {},
74
- },
75
- Priority: 0,
76
- Statement: {
77
- ManagedRuleGroupStatement: {
78
- Name: "AWSManagedRulesBotControlRuleSet",
79
- VendorName: "AWS",
80
- },
81
- },
82
- VisibilityConfig: {
83
- CloudWatchMetricsEnabled: true,
84
- MetricName: "AWSManagedRulesBotControlRuleSet",
85
- SampledRequestsEnabled: true,
86
- },
87
- },
88
- {
89
- Name: "AWS-AWSManagedRulesKnownBadInputsRuleSet",
90
- OverrideAction: {
91
- None: {},
92
- },
93
- Priority: 1,
94
- Statement: {
95
- ManagedRuleGroupStatement: {
96
- Name: "AWSManagedRulesKnownBadInputsRuleSet",
97
- VendorName: "AWS",
98
- },
99
- },
100
- VisibilityConfig: {
101
- CloudWatchMetricsEnabled: true,
102
- MetricName: "AWSManagedRulesKnownBadInputsRuleSet",
103
- SampledRequestsEnabled: true,
104
- },
105
- },
106
- {
107
- Name: "AWS-AWSManagedRulesCommonRuleSet",
108
- OverrideAction: {
109
- None: {},
110
- },
111
- Priority: 2,
112
- Statement: {
113
- ManagedRuleGroupStatement: {
114
- Name: "AWSManagedRulesCommonRuleSet",
115
- VendorName: "AWS",
116
- },
117
- },
118
- VisibilityConfig: {
119
- CloudWatchMetricsEnabled: true,
120
- MetricName: "AWSManagedRulesCommonRuleSet",
121
- SampledRequestsEnabled: true,
122
- },
123
- },
124
- {
125
- Name: "AWS-AWSManagedRulesAnonymousIpList",
126
- OverrideAction: {
127
- None: {},
128
- },
129
- Priority: 3,
130
- Statement: {
131
- ManagedRuleGroupStatement: {
132
- Name: "AWSManagedRulesAnonymousIpList",
133
- VendorName: "AWS",
134
- },
135
- },
136
- VisibilityConfig: {
137
- CloudWatchMetricsEnabled: true,
138
- MetricName: "AWSManagedRulesAnonymousIpList",
139
- SampledRequestsEnabled: true,
140
- },
141
- },
142
- {
143
- Name: "AWS-AWSManagedRulesAmazonIpReputationList",
144
- OverrideAction: {
145
- None: {},
146
- },
147
- Priority: 4,
148
- Statement: {
149
- ManagedRuleGroupStatement: {
150
- Name: "AWSManagedRulesAmazonIpReputationList",
151
- VendorName: "AWS",
152
- },
153
- },
154
- VisibilityConfig: {
155
- CloudWatchMetricsEnabled: true,
156
- MetricName: "AWSManagedRulesAmazonIpReputationList",
157
- SampledRequestsEnabled: true,
158
- },
159
- },
160
- {
161
- Name: "AWS-AWSManagedRulesAdminProtectionRuleSet",
162
- OverrideAction: {
163
- None: {},
164
- },
165
- Priority: 5,
166
- Statement: {
167
- ManagedRuleGroupStatement: {
168
- Name: "AWSManagedRulesAdminProtectionRuleSet",
169
- VendorName: "AWS",
170
- },
171
- },
172
- VisibilityConfig: {
173
- CloudWatchMetricsEnabled: true,
174
- MetricName: "AWSManagedRulesAdminProtectionRuleSet",
175
- SampledRequestsEnabled: true,
176
- },
177
- },
178
- {
179
- Name: "AWS-AWSManagedRulesSQLiRuleSet",
180
- OverrideAction: {
181
- None: {},
182
- },
183
- Priority: 6,
184
- Statement: {
185
- ManagedRuleGroupStatement: {
186
- Name: "AWSManagedRulesSQLiRuleSet",
187
- VendorName: "AWS",
188
- },
189
- },
190
- VisibilityConfig: {
191
- CloudWatchMetricsEnabled: true,
192
- MetricName: "AWSManagedRulesSQLiRuleSet",
193
- SampledRequestsEnabled: true,
194
- },
195
- },
196
- ],
197
- });
198
- });
199
- test("Test user provided acl props", () => {
200
- const stack = new cdk.Stack();
201
- const webaclProps = {
202
- defaultAction: {
203
- allow: {},
204
- },
205
- scope: "REGIONAL",
206
- visibilityConfig: {
207
- cloudWatchMetricsEnabled: false,
208
- metricName: "webACL",
209
- sampledRequestsEnabled: true,
210
- },
211
- rules: [
212
- defaults.wrapManagedRuleSet("AWSManagedRulesCommonRuleSet", "AWS", 0),
213
- defaults.wrapManagedRuleSet("AWSManagedRulesWordPressRuleSet", "AWS", 1),
214
- ],
215
- };
216
- deployConstruct(stack, webaclProps);
217
- const template = assertions_1.Template.fromStack(stack);
218
- template.hasResourceProperties("AWS::WAFv2::WebACL", {
219
- VisibilityConfig: {
220
- CloudWatchMetricsEnabled: false,
221
- MetricName: "webACL",
222
- SampledRequestsEnabled: true,
223
- },
224
- Rules: [
225
- {
226
- Name: "AWS-AWSManagedRulesCommonRuleSet",
227
- OverrideAction: {
228
- None: {},
229
- },
230
- Priority: 0,
231
- Statement: {
232
- ManagedRuleGroupStatement: {
233
- Name: "AWSManagedRulesCommonRuleSet",
234
- VendorName: "AWS",
235
- },
236
- },
237
- VisibilityConfig: {
238
- CloudWatchMetricsEnabled: true,
239
- MetricName: "AWSManagedRulesCommonRuleSet",
240
- SampledRequestsEnabled: true,
241
- },
242
- },
243
- {
244
- Name: "AWS-AWSManagedRulesWordPressRuleSet",
245
- OverrideAction: {
246
- None: {},
247
- },
248
- Priority: 1,
249
- Statement: {
250
- ManagedRuleGroupStatement: {
251
- Name: "AWSManagedRulesWordPressRuleSet",
252
- VendorName: "AWS",
253
- },
254
- },
255
- VisibilityConfig: {
256
- CloudWatchMetricsEnabled: true,
257
- MetricName: "AWSManagedRulesWordPressRuleSet",
258
- SampledRequestsEnabled: true,
259
- },
260
- },
261
- ],
262
- });
263
- });
264
- test("Test user provided partial acl props", () => {
265
- const stack = new cdk.Stack();
266
- const testName = 'test-name';
267
- const webaclProps = {
268
- name: testName
269
- };
270
- deployConstruct(stack, webaclProps);
271
- const template = assertions_1.Template.fromStack(stack);
272
- template.hasResourceProperties("AWS::WAFv2::WebACL", {
273
- Name: testName
274
- });
275
- });
276
- // --------------------------------------------------------------
277
- // Test existing web ACL
278
- // --------------------------------------------------------------
279
- test("Test existing web ACL", () => {
280
- const stack = new cdk.Stack();
281
- const webacl = new waf.CfnWebACL(stack, "test-webacl", {
282
- defaultAction: {
283
- allow: {},
284
- },
285
- scope: "REGIONAL",
286
- visibilityConfig: {
287
- cloudWatchMetricsEnabled: true,
288
- metricName: "webACL",
289
- sampledRequestsEnabled: true,
290
- },
291
- });
292
- deployConstruct(stack, undefined, webacl);
293
- const template = assertions_1.Template.fromStack(stack);
294
- template.hasResourceProperties("AWS::WAFv2::WebACL", {
295
- VisibilityConfig: {
296
- CloudWatchMetricsEnabled: true,
297
- MetricName: "webACL",
298
- SampledRequestsEnabled: true,
299
- },
300
- });
301
- template.resourceCountIs("AWS::WAFv2::WebACL", 1);
302
- });
303
- //# 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 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 { Template } from \"aws-cdk-lib/assertions\";\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 | any,\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\ntest('Confirm CheckWafWebAclProps is called', () => {\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('Error - Either provide existingWebaclObj or webaclProps, but not both.\\n');\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).toBeDefined();\n  expect(construct.appsyncApi).toBeDefined();\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"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\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  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"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\ntest(\"Test user provided partial acl props\", () => {\n  const stack = new cdk.Stack();\n  const testName = 'test-name';\n  const webaclProps = {\n    name: testName\n  };\n\n  deployConstruct(stack, webaclProps);\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::WAFv2::WebACL\", {\n    Name: testName\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  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::WAFv2::WebACL\", {\n    VisibilityConfig: {\n      CloudWatchMetricsEnabled: true,\n      MetricName: \"webACL\",\n      SampledRequestsEnabled: true,\n    },\n  });\n\n  template.resourceCountIs(\"AWS::WAFv2::WebACL\", 1);\n});\n"]}