Permanently Blocking IP Addresses with AWS WAF Rate-Based Rule Limit
10 September 2024
Table of contents
Permanently Blocking IP Addresses with AWS WAF Rate-Based Rule Limit
data:image/s3,"s3://crabby-images/ca0c0/ca0c08040557f4fe317139683ee066f9d166aaa7" alt="Blocking IP Addresses With Aws Waf Blocking IP Addresses With Aws Waf"
What is WAF?
WAF and Other Resource Pricing
data:image/s3,"s3://crabby-images/f1e51/f1e51fe6a5c77c105477e19c678c67d7e2cfaee1" alt="Waf Pricing Waf Pricing"
- Amazon API Gateway REST API
- Application Load Balancer
- AWS AppSync GraphQL API
- Amazon Cognito user pool
- AWS App Runner service
- AWS Verified Access instance
- PS: Here I am implementing this whole thing for the application load balancer.
Creating Web ACL and Rules
- Go to AWS WAF → Web ACLs → Select the region in which your load balancer or regional resource → Create Web ACL.
data:image/s3,"s3://crabby-images/d3e0e/d3e0e5a66accffa96f9443fe3e49a79179f0c561" alt="Creating Web Acl and Rules Creating Web Acl and Rules"
data:image/s3,"s3://crabby-images/ceff5/ceff5e733faf2f58c13b80be5b6a78a2cba442ed" alt="Creating Web Acl and Rules 2 Creating Web Acl and Rules 2"
data:image/s3,"s3://crabby-images/73a89/73a891f8a4046691382b25044fcc69bd5b9ac14d" alt="Associated Aws Resources Associated Aws Resources"
data:image/s3,"s3://crabby-images/91ba3/91ba367507267515236ba3ba61e24dd2276d1aeb" alt="Add Aws Resources Add Aws Resources"
data:image/s3,"s3://crabby-images/3b80c/3b80c670a439e6da6c260af3ba2c293e845db2b6" alt="Add Rules Add Rules"
- Rule type: Rule builder
- Type: Rate-based rule
data:image/s3,"s3://crabby-images/ef8a6/ef8a6e4a80f0c6918d79badb232ef9a271ecd5ac" alt="Rule Type Rule Type"
- Rate Limit: 100 (You can specify according to your traffic)
- Evaluation window: 1 minute (This means if someone makes more than 100 requests in 1 minute, then their IP will be blocked)
- Request aggregation: IP address in header (Why this option? Let’s discuss it later in this blog)
data:image/s3,"s3://crabby-images/85213/85213c55e5770a95ce4143dce62d845a846762d1" alt="Rate Limiting Criteria Rate Limiting Criteria"
- Header field name: X-Forwarded-For
data:image/s3,"s3://crabby-images/85180/85180469bf91a4248015c859927736010c1f8bb9" alt="Header Field Name X Forwarded For Header Field Name X Forwarded For"
- Create an IP set that contains IP addresses of attackers.
- Create a rule in Web ACL that blocks IP addresses from attackers IP set.
- Create Lambda Function that reads the list of Blocked IPs by Rate-Base Rule, and add those IPs to the attacker's IP set.
- Create one Eventbridge Rule that triggers lambda functions every minute. So, we can keep the attackers IP set list updated with newly blocked IPs.
Creating Lambda, IP set, IAM role and Eventbridge rule
- You can find the CloudFormation template here.
- Go to CloudFormation → Stacks → Create Stack → With New Resources (Standard).
- Prepare template: Choose an existing template. Template source: Upload a template file. (I've stored the template in S3, so you can use the S3 URL but you can directly upload a .YAML file.
data:image/s3,"s3://crabby-images/20f84/20f84c232558b779fecabc5f2ae57c2c137ce2f9" alt="Create Stack Create Stack"
- RateBasedRuleName: Name of our Rate-base- rule created in Web ACL.
- Scope: REGIONAL ( I am using ALB so it is a regional resource.)
- WebACLId: It can be found at Web ALC dashboard (AWS WAF → Web ACLs)
- WebACLName: Name of Web ACL.
data:image/s3,"s3://crabby-images/bb52f/bb52f3716730f9a98c13b672101e5c3e3d1fc60c" alt="Provide a Stack Name Image Provide a Stack Name Image"
data:image/s3,"s3://crabby-images/3fba9/3fba99136498393c696362d4049fcfa7accbb3d5" alt="Aws Iam Role Aws Iam Role"
Create IP Set Blocking Rule
- Go to AWS WAF → Web ACLs → your Web ACL → Rules → Add my own rules.
data:image/s3,"s3://crabby-images/c0989/c0989f4d49022faf8d91c9606e0ae2287a6ab153" alt="Testing Rate Limiter Testing Rate Limiter"
- Rule type: IP set
- Name: xxxxx
- IP set: Select IP set created by CloudFormation.
data:image/s3,"s3://crabby-images/1dba9/1dba9bf3b749301d91982e4ac60bf8b5176969ba" alt="Rule Type IP Set Rule Type IP Set"
- IP address to use as the originating address: IP address in header
- Header field name: X-Forwarded-For
- Position inside header: Any IP addresses
data:image/s3,"s3://crabby-images/5e319/5e319f5b797001ef1c2cd565340484480073406f" alt="IP Address to Use as the Og Adress IP Address to Use as the Og Adress"
- Action: Block
data:image/s3,"s3://crabby-images/cef89/cef89b319fcb80fd7dd7d5d3d080c5dd88507ee4" alt="Action Block Action Block"
data:image/s3,"s3://crabby-images/d78cf/d78cf1d06f998928c52e400755f5483bf500edd6" alt="Set Rule Priority Set Rule Priority"
Testing
- Install ApacheBench on Ubuntu.
sudo apt-get update
sudo apt-get install apache2-utils
- Creating a shell script that sends 200 requests per minute to the domain (in other words, to the server)
#!/bin/bash
for i in {1..20}
do
ab -n 10 -c 1 -H "X-Forwarded-For: 1.2.3.4" http://your-server-endpoint/
sleep 3
done
- To run a script, run the following commands:
chmod +x test.sh
./test.sh
data:image/s3,"s3://crabby-images/e042f/e042ff7f55a9af0948a5ddbd1b34e24e88dbe006" alt="Add IP Addresses Add IP Addresses"
Why Are We Using ‘X-Forwarded-For’?
data:image/s3,"s3://crabby-images/c140e/c140e89fff2a2ab2edeb46debcb258b69407828b" alt="D Do S Attacks Using HTTP Proxies D Do S Attacks Using HTTP Proxies"
- If you use the Source IP address to block requests, then there is a high chance that your regular user might get blocked if they exceed the limit, while the attacker will still be able to increase the load of your server by using proxies.
- The ‘X-Forwarded-For’ header is only present in requests that are coming from HTTP proxies or load balancers, making it easier to differentiate between regular users and users with bad intentions.
WRITTEN BY
data:image/s3,"s3://crabby-images/2837a/2837a1bf51f8437ce9cbd78157f740a3fd8dfa99" alt=""
Pruthvi Menpara
Pruthvi is a cloud computing architect who makes sure businesses scale and perform at their best using AWS and Azure. He’s passionate about building robust cloud infrastructures that provide the perfect balance of security and scalability.
WRITTEN BY
Pruthvi Menpara
Pruthvi is a cloud computing architect who makes sure businesses scale and perform at their best using AWS and Azure. He’s passionate about building robust cloud infrastructures that provide the perfect balance of security and scalability.
More
An interesting read? Here is more related to it.
03 December 2024
Hitali BhesaniyaMaking IT Possible
Making IT Possible
Making IT Possible
Making IT Possible
Making IT Possible
Making IT Possible
India (HQ)
201, iSquare Corporate Park, Science City Road, Ahmedabad-380060, Gujarat, India
For Sales
[email protected]
Looking For Jobs
Apply Now