Profile Applicability:
Level 2
Description
AWS WAF is a web application firewall that helps protect your web applications and APIs from common web exploits and vulnerabilities. By using AWS WAF with CloudFront distributions, you can block malicious requests before they reach your servers, enhancing the security of your web applications.
Rationale
- Enhanced Security: Protects against common web exploits and vulnerabilities. 
- Improved Performance: Blocks malicious requests before they reach your servers, reducing load and improving performance. 
- Compliance: Ensures adherence to security best practices and regulatory requirements. 
Impact
Pros:
- Enhances security by blocking malicious requests. 
- Reduces load on origin servers, improving performance. 
- Ensures compliance with security standards. 
Cons:
- Requires additional configuration and management of WAF rules. 
- Potential temporary disruption during the setup process. 
Default Value
By default, AWS WAF is not enabled for CloudFront distributions. It must be explicitly configured and associated with the distribution.
Pre-Requisite
IAM Permissions:
- cloudfront:GetDistribution 
- cloudfront:UpdateDistribution 
- waf:GetWebACL 
- waf:AssociateWebACL 
- AWS CLI installed and configured. 
Remediation
Test Plan:
Using AWS Console:
- Sign in to the AWS Management Console. 
- Navigate to the CloudFront Dashboard. 
- Click on the Distributions tab in the top left navigation menu. 
- Select the Distribution you want to audit. 
- Click on the General tab in the top menu. 
- Check if AWS WAF is enabled and associated with the distribution. 
Using AWS CLI:
Check WAF Status:
aws cloudfront get-distribution --id <distribution-id> --query 'Distribution.DistributionConfig.WebACLId'
Implementation Steps:
Using AWS Console:
- Sign in to the AWS Management Console. 
- Navigate to the CloudFront Dashboard.  
- Click on the Distributions tab in the top left navigation menu. 
- Select the Distribution you want to modify.  
- Click on the General tab in the top menu. 
- Click Edit to modify the distribution settings.  
- Enable AWS WAF and associate a Web ACL (Web Access Control List). 
- Click Save changes to save the changes. 
Using AWS CLI:
Associate a Web ACL with the CloudFront distribution:
aws cloudfront update-distribution --id <distribution-id> --distribution-config file://distconfig-waf.json
Backout Plan
Using AWS Console:
- Navigate to the CloudFront Dashboard. 
- Select the Distribution. 
- Click Edit Attributes. 
- Revert to the previous configuration by disassociating the Web ACL. 
- Click Save changes to save the changes. 
Using AWS CLI:
aws cloudfront update-distribution --id <distribution-id> --distribution-config file://distconfig-original.json
