CloudFrunt - A Tool For Identifying Misconfigured CloudFront Domains
CloudFrunt is a tool for identifying misconfigured CloudFront domains.
Background
CloudFront is a Content Delivery Network (CDN) provided by Amazon Web Services (AWS). CloudFront users create "distributions" that serve content from specific sources (an S3 bucket, for example).
Each CloudFront distribution has a unique endpoint for users to point their DNS records to (ex. d111111abcdef8.cloudfront.net). All of the domains using a specific distribution need to be listed in the "Alternate Domain Names (CNAMEs)" field in the options for that distribution.
When a CloudFront endpoint receives a request, it does NOT automatically serve content from the corresponding distribution. Instead, CloudFront uses the HOST header of the request to determine which distribution to use. This means two things:
- If the HOST header does not match an entry in the "Alternate Domain Names (CNAMEs)" field of the intended distribution, the request will fail.
- Any other distribution that contains the specific domain in the HOST header will receive the request and respond to it normally.
This is what allows the domains to be hijacked. There are many cases where a CloudFront user fails to list all the necessary domains that might be received in the HOST header. For example:
- The domain "test.disloops.com" is a CNAME record that points to "disloops.com".
- The "disloops.com" domain is set up to use a CloudFront distribution.
- Because "test.disloops.com" was not added to the "Alternate Domain Names (CNAMEs)" field for the distribution, requests to "test.disloops.com" will fail.
- Another user can create a CloudFront distribution and add "test.disloops.com" to the "Alternate Domain Names (CNAMEs)" field to hijack the domain.
This means that the unique endpoint that CloudFront binds to a single distribution is effectively meaningless. A request to one specific CloudFront subdomain is not limited to the distribution it is associated with.
Installation
$ pip install boto3
$ pip install netaddr
$ pip install dnspython
$ git clone https://github.com/disloops/cloudfrunt.git
$ cd cloudfrunt
$ git clone https://github.com/darkoperator/dnsrecon.git
CloudFrunt expects the dnsrecon script to be cloned into a subdirectory called dnsrecon.Usage
cloudfrunt.py [-h] [-l TARGET_FILE] [-d DOMAINS] [-o ORIGIN] [-i ORIGIN_ID] [-s] [-N]
-h, --help Show this message and exit
-s, --save Save the results to results.txt
-N, --no-dns Do not use dnsrecon to expand scope
-l, --target-file TARGET_FILE File containing a list of domains (one per line)
-d, --domains DOMAINS Comma-separated list of domains to scan
-o, --origin ORIGIN Add vulnerable domains to new distributions with this origin
-i, --origin-id ORIGIN_ID The origin ID to use with new distributions
Example
$ python cloudfrunt.py -o cloudfrunt.com.s3-website-us-east-1.amazonaws.com -i S3-cloudfrunt -l list.txt
CloudFrunt v1.0.3
[+] Enumerating DNS entries for google.com
[-] No issues found for google.com
[+] Enumerating DNS entries for disloops.com
[+] Found CloudFront domain --> cdn.disloops.com
[+] Found CloudFront domain --> test.disloops.com
[-] Potentially misconfigured CloudFront domains:
[#] --> test.disloops.com
[+] Created new CloudFront distribution EXBC12DE3F45G
[+] Added test.disloops.com to CloudFront distribution EXBC12DE3F45G
Related articles
- Hacking Tools Hardware
- Pentest Tools Online
- Hacks And Tools
- Hacking Tools For Pc
- Hack Tool Apk
- Pentest Tools Url Fuzzer
- Hack Tools For Pc
- Pentest Tools Nmap
- Hacking Tools For Windows
- Game Hacking
- Hacker Tools
- World No 1 Hacker Software
- Nsa Hacker Tools
- Hacking Tools Usb
- What Is Hacking Tools
- Hack Tool Apk
- Hacker Tools Github
- Hacker Tools Free Download
- Hacker Tools 2019
- Hack Tools For Games
- Hack And Tools
- Hacking App
- Bluetooth Hacking Tools Kali
- Hacking Tools Online
- Hack Tools For Pc
- Pentest Tools
- Beginner Hacker Tools
- Pentest Tools Kali Linux
- Hacking Tools For Mac
- Hack Tool Apk
- Black Hat Hacker Tools
- Hacking Apps
- Tools Used For Hacking
- Hacking Tools Free Download
- New Hacker Tools
- World No 1 Hacker Software
- Hacking Tools For Beginners
- Hack Tools For Windows
- Install Pentest Tools Ubuntu
- Best Hacking Tools 2020
- Hacking Tools 2020
- How To Install Pentest Tools In Ubuntu
- Hacker Tools Github
- Hack Tools
- Underground Hacker Sites
- Hacking Tools Software
- Hacking Tools For Pc
- Nsa Hack Tools Download
- Pentest Reporting Tools
- Game Hacking
- Hacking Tools
- Hacker Tools Free
- Pentest Tools Android
- Tools Used For Hacking
- Pentest Reporting Tools
- Hacker Tools
- Hacker Tools For Pc
- Nsa Hacker Tools
- Hacking Tools For Beginners
- Hak5 Tools
- Best Pentesting Tools 2018
- Hack Website Online Tool
- Hacking Tools 2019
- Hack Tools Online
- Hackers Toolbox
- Hacking Apps
- Hack Tools Pc
- Pentest Tools Kali Linux
- Physical Pentest Tools
- Pentest Tools Online
- What Are Hacking Tools
- Hack Tools Github
- How To Hack
- Pentest Tools Apk
- Hacker Tools
- Hacking Tools Usb
- Hacker Tools
- Pentest Tools Nmap
- Hacks And Tools
- Hack Tool Apk
- Pentest Tools Apk
- Hacking Tools Github
- Hak5 Tools
- Hacking Tools 2019
- Pentest Tools Website
- Hacking Tools Pc
- Hak5 Tools
- New Hack Tools
- How To Hack
- Beginner Hacker Tools
- Hacker Tools Free
- Pentest Tools Windows
- Hackrf Tools
- Beginner Hacker Tools
0 Comments:
Post a Comment
Subscribe to Post Comments [Atom]
<< Home