Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/prevade/cloudjack
Route53/CloudFront Vulnerability Assessment Utility
https://github.com/prevade/cloudjack
aws cloudfront route53 vulnerability
Last synced: 26 days ago
JSON representation
Route53/CloudFront Vulnerability Assessment Utility
- Host: GitHub
- URL: https://github.com/prevade/cloudjack
- Owner: prevade
- License: gpl-3.0
- Created: 2017-09-14T06:50:42.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2023-09-11T18:01:59.000Z (over 1 year ago)
- Last Synced: 2024-08-03T12:01:30.882Z (4 months ago)
- Topics: aws, cloudfront, route53, vulnerability
- Language: Python
- Homepage: https://www.prevade.com
- Size: 38.1 KB
- Stars: 81
- Watchers: 6
- Forks: 23
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-cloud-security - 地址
- awesome-cloud-sec - cloudjack - - Route53/CloudFront Vulnerability Assessment Utility (Other Awesome Lists / Subdomain Takeover)
README
# CloudJack
### AWS Route53/CloudFront/S3 Vulnerability Assessment Utility
CloudJack assesses AWS accounts for subdomain hijacking vulnerabilities as a result of decoupled Route53 and CloudFront configurations. This vulnerability exists if a Route53 alias references 1) a deleted CloudFront web distribution or 2) an active CloudFront web distribution with deleted CNAME(s).
If this decoupling is discovered by an attacker, they can simply create a CloudFront web distribution and/or CloudFront NAME(s) in their account that match the victim account's Route53 A record host name. Exploitation of this vulnerability results in the ability to spoof the victim's web site content, which otherwise would have been accessed through the victim's account.
CloudJacking video at Austin OWASP May 2018: https://www.youtube.com/watch?v=tMMpK0kd5H8
Requirements:
1. AWS IAM access key ID and corresponding secret key
2. AWS CLI installation configured with profile(s), access key ID(s), and secret key(s) in ~/.aws/credentials[default]
aws_access_key_id=
aws_secret_access_key=and/or
[myprofile]
aws_access_key_id=
aws_secret_access_key=3. AWS IAM policy allowing Route53 ListHostedZones and ListResourceRecordSets actions
4. AWS IAM policy allowing CloudFront ListDistributions actions
5. Python and AWS SDK boto3 package
- pip install boto3Usage:
$ python cloudjack.py -o [text|json] -p [profile]Examples:
- $ python cloudjack.py -o json -p default
- $ python cloudjack.py -o text -p default
- $ python cloudjack.py -o json -p myprofile
- $ python cloudjack.py -o text -p myprofileWishlist:
1. Assess S3/CloudFront decoupling
2. Offensive reconnaissance and exploitation featuresNotes:
Python3 now supported. Use cloudjack-p2.py for Python2.
References:
- http://docs.aws.amazon.com/Route53/latest/APIReference/API_ListHostedZones.html
- http://docs.aws.amazon.com/Route53/latest/APIReference/API_ListResourceRecordSets.html
- http://docs.aws.amazon.com/cloudfront/latest/APIReference/API_ListDistributions.html
- http://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_access-keys.html