UNPKG

@aws-solutions-constructs/core

Version:
305 lines 30.8 kB
"use strict"; /** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance * with the License. A copy of the License is located at * * http://www.apache.org/licenses/LICENSE-2.0 * * or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES * OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions * and limitations under the License. */ Object.defineProperty(exports, "__esModule", { value: true }); const aws_cdk_lib_1 = require("aws-cdk-lib"); const waf = require("aws-cdk-lib/aws-wafv2"); const defaults = require(".."); const assertions_1 = require("aws-cdk-lib/assertions"); const __1 = require(".."); test('Test construct with default props', () => { // Stack const stack = new aws_cdk_lib_1.Stack(); // Build WAF web ACL defaults.buildWebacl(stack, 'REGIONAL', {}); const template = assertions_1.Template.fromStack(stack); template.hasResourceProperties("AWS::WAFv2::WebACL", { Scope: "REGIONAL", VisibilityConfig: { CloudWatchMetricsEnabled: true, MetricName: "webACL", SampledRequestsEnabled: true }, Rules: [ { Name: "AWS-AWSManagedRulesBotControlRuleSet", OverrideAction: { None: {} }, Priority: 0, Statement: { ManagedRuleGroupStatement: { Name: "AWSManagedRulesBotControlRuleSet", VendorName: "AWS" } }, VisibilityConfig: { CloudWatchMetricsEnabled: true, MetricName: "AWSManagedRulesBotControlRuleSet", SampledRequestsEnabled: true } }, { Name: "AWS-AWSManagedRulesKnownBadInputsRuleSet", OverrideAction: { None: {} }, Priority: 1, Statement: { ManagedRuleGroupStatement: { Name: "AWSManagedRulesKnownBadInputsRuleSet", VendorName: "AWS" } }, VisibilityConfig: { CloudWatchMetricsEnabled: true, MetricName: "AWSManagedRulesKnownBadInputsRuleSet", SampledRequestsEnabled: true } }, { Name: "AWS-AWSManagedRulesCommonRuleSet", OverrideAction: { None: {} }, Priority: 2, Statement: { ManagedRuleGroupStatement: { Name: "AWSManagedRulesCommonRuleSet", VendorName: "AWS" } }, VisibilityConfig: { CloudWatchMetricsEnabled: true, MetricName: "AWSManagedRulesCommonRuleSet", SampledRequestsEnabled: true } }, { Name: "AWS-AWSManagedRulesAnonymousIpList", OverrideAction: { None: {} }, Priority: 3, Statement: { ManagedRuleGroupStatement: { Name: "AWSManagedRulesAnonymousIpList", VendorName: "AWS" } }, VisibilityConfig: { CloudWatchMetricsEnabled: true, MetricName: "AWSManagedRulesAnonymousIpList", SampledRequestsEnabled: true } }, { Name: "AWS-AWSManagedRulesAmazonIpReputationList", OverrideAction: { None: {} }, Priority: 4, Statement: { ManagedRuleGroupStatement: { Name: "AWSManagedRulesAmazonIpReputationList", VendorName: "AWS" } }, VisibilityConfig: { CloudWatchMetricsEnabled: true, MetricName: "AWSManagedRulesAmazonIpReputationList", SampledRequestsEnabled: true } }, { Name: "AWS-AWSManagedRulesAdminProtectionRuleSet", OverrideAction: { None: {} }, Priority: 5, Statement: { ManagedRuleGroupStatement: { Name: "AWSManagedRulesAdminProtectionRuleSet", VendorName: "AWS" } }, VisibilityConfig: { CloudWatchMetricsEnabled: true, MetricName: "AWSManagedRulesAdminProtectionRuleSet", SampledRequestsEnabled: true } }, { Name: "AWS-AWSManagedRulesSQLiRuleSet", OverrideAction: { None: {} }, Priority: 6, Statement: { ManagedRuleGroupStatement: { Name: "AWSManagedRulesSQLiRuleSet", VendorName: "AWS" } }, VisibilityConfig: { CloudWatchMetricsEnabled: true, MetricName: "AWSManagedRulesSQLiRuleSet", SampledRequestsEnabled: true } } ] }); template.resourceCountIs('AWS::WAFv2::WebACL', 1); template.resourceCountIs('AWS::WAFv2::WebACLAssociation', 0); }); test('Test deployment w/ user provided custom properties', () => { // Stack const stack = new aws_cdk_lib_1.Stack(); // Build WAF web ACL const props = { scope: 'CLOUDFRONT', defaultAction: { allow: {} }, visibilityConfig: { cloudWatchMetricsEnabled: false, metricName: 'webACL', sampledRequestsEnabled: true }, rules: [ defaults.wrapManagedRuleSet("AWSManagedRulesCommonRuleSet", "AWS", 0), defaults.wrapManagedRuleSet("AWSManagedRulesWordPressRuleSet", "AWS", 1), ] }; defaults.buildWebacl(stack, 'CLOUDFRONT', { webaclProps: props }); assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::WAFv2::WebACL", { Scope: "CLOUDFRONT", VisibilityConfig: { CloudWatchMetricsEnabled: false, MetricName: "webACL", SampledRequestsEnabled: true }, Rules: [ { Name: "AWS-AWSManagedRulesCommonRuleSet", OverrideAction: { None: {} }, Priority: 0, Statement: { ManagedRuleGroupStatement: { Name: "AWSManagedRulesCommonRuleSet", VendorName: "AWS" } }, VisibilityConfig: { CloudWatchMetricsEnabled: true, MetricName: "AWSManagedRulesCommonRuleSet", SampledRequestsEnabled: true } }, { Name: "AWS-AWSManagedRulesWordPressRuleSet", OverrideAction: { None: {} }, Priority: 1, Statement: { ManagedRuleGroupStatement: { Name: "AWSManagedRulesWordPressRuleSet", VendorName: "AWS" } }, VisibilityConfig: { CloudWatchMetricsEnabled: true, MetricName: "AWSManagedRulesWordPressRuleSet", SampledRequestsEnabled: true } } ] }); }); test('Test deployment w/ user provided partial custom properties', () => { // Stack const stack = new aws_cdk_lib_1.Stack(); const testName = 'test-name'; // Build WAF web ACL const props = { name: testName }; defaults.buildWebacl(stack, 'CLOUDFRONT', { webaclProps: props }); assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::WAFv2::WebACL", { Name: testName }); }); test('Test deployment w/ existing WAF web ACL provided', () => { // Stack const stack = new aws_cdk_lib_1.Stack(); // Build WAF web ACL const testWaf = (0, __1.buildWebacl)(stack, 'CLOUDFRONT', {}); const newWaf = defaults.buildWebacl(stack, 'CLOUDFRONT', { existingWebaclObj: testWaf }); expect(newWaf).toBe(testWaf); }); // --------------------------- // Prop Tests // --------------------------- test('Test WebACL bad props', () => { const stack = new aws_cdk_lib_1.Stack(); const wafProps = { scope: 'CLOUDFRONT', defaultAction: { allow: {} }, visibilityConfig: { cloudWatchMetricsEnabled: false, metricName: 'webACL', sampledRequestsEnabled: true }, rules: [ defaults.wrapManagedRuleSet("AWSManagedRulesCommonRuleSet", "AWS", 0), defaults.wrapManagedRuleSet("AWSManagedRulesWordPressRuleSet", "AWS", 1), ] }; const wafPropsTwo = { scope: 'CLOUDFRONT', defaultAction: { allow: {} }, visibilityConfig: { cloudWatchMetricsEnabled: false, metricName: 'webACL', sampledRequestsEnabled: true }, rules: [ defaults.wrapManagedRuleSet("AWSManagedRulesCommonRuleSet", "AWS", 0), defaults.wrapManagedRuleSet("AWSManagedRulesWordPressRuleSet", "AWS", 1), ] }; const acl = new waf.CfnWebACL(stack, 'test', wafProps); const props = { existingWebaclObj: acl, webaclProps: wafPropsTwo, }; const app = () => { defaults.CheckWafWebAclProps(props); }; // Assertion expect(app).toThrowError('Error - Either provide existingWebaclObj or webaclProps, but not both.\n'); }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"waf-helper.test.js","sourceRoot":"","sources":["waf-helper.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\nimport { Stack } from 'aws-cdk-lib';\nimport * as waf from \"aws-cdk-lib/aws-wafv2\";\nimport * as defaults from '..';\nimport { Template } from 'aws-cdk-lib/assertions';\nimport { buildWebacl } from '..';\n\ntest('Test construct with default props', () => {\n  // Stack\n  const stack = new Stack();\n  // Build WAF web ACL\n  defaults.buildWebacl(stack, 'REGIONAL', {});\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::WAFv2::WebACL\", {\n    Scope: \"REGIONAL\",\n    VisibilityConfig: {\n      CloudWatchMetricsEnabled: true,\n      MetricName: \"webACL\",\n      SampledRequestsEnabled: true\n    },\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  template.resourceCountIs('AWS::WAFv2::WebACL', 1);\n  template.resourceCountIs('AWS::WAFv2::WebACLAssociation', 0);\n});\n\ntest('Test deployment w/ user provided custom properties', () => {\n  // Stack\n  const stack = new Stack();\n\n  // Build WAF web ACL\n  const props: waf.CfnWebACLProps = {\n    scope: 'CLOUDFRONT',\n    defaultAction: {\n      allow: {}\n    },\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  defaults.buildWebacl(stack, 'CLOUDFRONT', {\n    webaclProps: props\n  });\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::WAFv2::WebACL\", {\n    Scope: \"CLOUDFRONT\",\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 deployment w/ user provided partial custom properties', () => {\n  // Stack\n  const stack = new Stack();\n  const testName = 'test-name';\n  // Build WAF web ACL\n  const props = {\n    name: testName\n  };\n\n  defaults.buildWebacl(stack, 'CLOUDFRONT', {\n    webaclProps: props\n  });\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::WAFv2::WebACL\", {\n    Name: testName\n  });\n});\n\ntest('Test deployment w/ existing WAF web ACL provided', () => {\n  // Stack\n  const stack = new Stack();\n  // Build WAF web ACL\n  const testWaf = buildWebacl(stack, 'CLOUDFRONT', {});\n  const newWaf = defaults.buildWebacl(stack, 'CLOUDFRONT', {\n    existingWebaclObj: testWaf\n  });\n\n  expect(newWaf).toBe(testWaf);\n});\n\n// ---------------------------\n// Prop Tests\n// ---------------------------\ntest('Test WebACL bad props', () => {\n  const stack = new Stack();\n  const wafProps: waf.CfnWebACLProps = {\n    scope: 'CLOUDFRONT',\n    defaultAction: {\n      allow: {}\n    },\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  const wafPropsTwo: waf.CfnWebACLProps = {\n    scope: 'CLOUDFRONT',\n    defaultAction: {\n      allow: {}\n    },\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  const acl: waf.CfnWebACL = new waf.CfnWebACL(stack, 'test',  wafProps);\n\n  const props: defaults.WafWebAclProps = {\n    existingWebaclObj: acl,\n    webaclProps: wafPropsTwo,\n  };\n\n  const app = () => {\n    defaults.CheckWafWebAclProps(props);\n  };\n\n  // Assertion\n  expect(app).toThrowError('Error - Either provide existingWebaclObj or webaclProps, but not both.\\n');\n});\n"]}