Skip to content

Latest commit

 

History

History
53 lines (45 loc) · 3.15 KB

README.md

File metadata and controls

53 lines (45 loc) · 3.15 KB

Abandoned_S3_Bucket_Takeover

Pylint CodeQL Bandit License: MIT

image

Overview

Solution to hunt for possible subdomain takeover via abandoned Amazon S3 Bucket.

This uses asynchronous requests (aiohttp) to a given list of (sub)domains and search for a pattern matching an abandoned Amazon S3 Bucket (404 page containing the keyword NoSuchBucket).

output-onlinegiftools (1)

Prerequisites

To obtain the script, download this repo's content from GitHub:

git clone https://github.com/ob1lan/Abandoned_S3_Bucket_Takeover.git

To install the prerequisite modules, use the requirements.txt file as follow:

pip install -r requirements.txt

Usage

The domains.txt file

In order to use the script, you need to have a domains.txt file, containing 1 domain per line, in the working directory. This file can be easily generated with any tool of your liking, such as amas.

Example with amass

amass enum -active -src -brute -o amass-results.txt -d mydomain.com

# Once amass finished finding all subdomains for the input domain
cat amass-results.txt | awk -F ] '{print $2}' | sed -e 's/  */ /g' -e 's/^ *\(.*\) *$/\1/' > domains.txt

Using the script

This is how you would use the script, given you installed all prerequisites modules and got a domains.txt file in the same directory as the script:

python hunt_abandoned_bucket.py

Once the script executed, the following files are created in the same directory:

  • findings.txt : lists all records matching the criteria (returns a 404 and the common 'NoSuchBucket' page)
  • errors.txt : lists all errors encountered by the script while querying the urls (timeout, TooManyRedirects, etc...)
  • excluded.txt : you can use this file to exclude (sub)domains in future runs

Limiting concurrent requests

The requests are limited with a Semaphore to avoid possible issues, the default value is 50 concurrent requests maximum. This can be changed by modifying the value of the 'sem' variable in the script:

sem = asyncio.Semaphore(50)

To Do

  • Improve the script and have it peer-reviewed
  • Take args to display help and set the location of the domains.txt, along with the Semaphore value
  • Verify the retry decoration actually work (doubts)
  • Containerize along with amass