Skip to main content
MEDIUMCloudFrontSecurity

CloudFront WAF Missing

cloudfront-waf-missing

What this rule checks

Detects CloudFront distributions without WAF association.

How to fix it

  1. 1Associate AWS WAF web ACL with CloudFront distribution
  2. 2Configure WAF rules for common attack patterns
FlaggedNo webAclId is set on the distribution, so DistributionConfig.WebACLId is absent. The check flags distributions that have no AWS WAF WebACL associated.
import * as cloudfront from 'aws-cdk-lib/aws-cloudfront';
import * as origins from 'aws-cdk-lib/aws-cloudfront-origins';

new cloudfront.Distribution(this, 'Dist', {
  defaultBehavior: { origin: new origins.HttpOrigin('origin.example.com') },
});
FixedAssociating a WAF WebACL ARN via webAclId populates DistributionConfig.WebACLId, so the distribution is protected by WAF and the finding clears.
import * as cloudfront from 'aws-cdk-lib/aws-cloudfront';
import * as origins from 'aws-cdk-lib/aws-cloudfront-origins';

new cloudfront.Distribution(this, 'Dist', {
  defaultBehavior: { origin: new origins.HttpOrigin('origin.example.com') },
  webAclId: 'arn:aws:wafv2:us-east-1:111122223333:global/webacl/example/00000000-0000-0000-0000-000000000000',
});

CDK Insights pinpoints the exact file and line in your CDK source for every finding, so you can jump straight to the fix.

Affected resource types

AWS::CloudFront::Distribution

Compliance frameworks

SOC2PCI-DSSNIST

AWS documentation

Read the AWS guidance

Intentional? Suppress this finding

Sometimes a flag is deliberate โ€” a genuinely public endpoint, say. You can dismiss cloudfront-waf-missing and the reason is kept in the report, not silently hidden.

In .cdk-insights.json:

{
  "ignoreRules": [
    { "id": "cloudfront-waf-missing", "reason": "Why this is intentional" }
  ]
}

Or inline in your CDK code:

Validations.of(scope).acknowledge({
  id: 'cdk-insights::cloudfront-waf-missing',
  reason: 'Why this is intentional',
});

Use the rule ID cloudfront-waf-missing shown above โ€” not the CDK-* ID from SARIF / GitHub code scanning. To dismiss every finding on one construct instead, use ignorePaths. Suppression docs โ†’

Catch this in your stack

$ npx cdk-insights scan

CDK Insights runs this and 118+ other rules locally against your synthesised CDK app โ€” free, no account, your code never leaves your machine.

More CloudFront rules