Skip to content

stanislav-web/OpenDoor

Repository files navigation

OWASP Directory Access Scanner (redesigned)

PyPI version Build Status Coverage Status Code Health Codacy Badge Say Thanks!

This application scans the site directories and find all possible ways to login, empty directories and entry points. Scans conducted in the dictionary that is included in this application. This software is written for informational purposes and is an open source product under the GPL license.

  • Current v3.0.2-beta (31.01.2017)
    • Directories - 26322
    • Subdomains - 101000

Testing of the software on the commercial systems and organizations is prohibited!

Alt text

Requirements

  • Unix
  • Python 2.6.x
  • Python 2.7.x

Maintainers

Install Dependencies

sudo pip install -r requirements.txt
chmod +x opendoor.py

Also, you have to install socksipy package if you'll use socks as proxy

sudo apt-get install python-socksipy

Implements

  • multithreading control
  • scan's reports
  • directories scanner
  • subdomains scanner
  • HTTP(S) (PORT) support
  • HTTP(S)/SOCKS proxies
  • dynamic request header
  • detect redirects
  • detect index of/ Apache
  • detect large files
  • custom wordlst's prefixes
  • custom wordlists, proxies, ignore lists
  • debug levels (1-3)
  • randomization techniques
    • random user-agent per request
    • random proxy per request
    • wordlists shuffling

Changelog (last changes)

v3.0.1-alfa (31.01.2017)

- relieved of unnecessary dependencies
- fully optimized code inside
- user-friendly interface
- multiple reporters (std,txt,json)
- added external wordlists support
- added external proxylist support
- added wordlist shuffling
- wordlst's prefixes
- added multithreading control
- dynamic and smart requests (cookies + accept headers)
- apache index of/ and files detection

Basic usage

 python opendoor.py --host http://www.example.com

Help

usage: opendoor.py [-h] [--host HOST] [-p PORT] [-m METHOD] [-t THREADS]
                   [-d DELAY] [--timeout TIMEOUT] [-r RETRIES]
                   [--accept-cookies] [--debug DEBUG] [--tor]
                   [--torlist TORLIST] [--proxy PROXY] [-s SCAN] [-w WORDLIST]
                   [--reports REPORTS] [--random-agent] [--random-list]
                   [--prefix PREFIX] [-i] [--update] [--version] [--examples]

optional arguments:
  -h, --help            show this help message and exit

required named options:
  --host HOST           Target host (ip); --host http://example.com

Application tools:
  --update              Update from CVS
  --version             Get current version
  --examples            Examples of usage

Debug tools:
  --debug DEBUG         Debug level 1 - 3

Request tools:
  -p PORT, --port PORT  Custom port (Default 80)
  -m METHOD, --method METHOD
                        HTTP method (use HEAD as default)
  -d DELAY, --delay DELAY
                        Delay between request's threads
  --timeout TIMEOUT     Request timeout (30 sec default)
  -r RETRIES, --retries RETRIES
                        Max retries to reconnect (default 3)
  --accept-cookies      Accept and route cookies from responses
  --tor                 Using proxylist
  --torlist TORLIST     Path to external proxylist
  --proxy PROXY         Custom permanent proxy server
  --random-agent        Randomize user-agent per request

Sniff tools:
  -i, --indexof         Detect Apache Index of/

Stream tools:
  -t THREADS, --threads THREADS
                        Allowed threads

Wordlist tools:
  -s SCAN, --scan SCAN  Scan type scan=directories or scan=subdomains
  -w WORDLIST, --wordlist WORDLIST
                        Path to external wordlist
  --reports REPORTS     Scan reports (json,std,txt)
  --random-list         Shuffle scan list
  --prefix PREFIX       Append path prefix to scan host

Test

pip install unittest2
coverage run --source=opendoor setup.py test

Contributors

If you like to contribute to the development of the project in that case pull requests are open for you. Also, you can suggest an ideas and create a task in my track list

Issues

Documentation