Skip to main content

A password guessing API.

Project description

BruteLoops

A dead simple library providing the foundational logic for efficient password brute force attacks against authentication interfaces.

Documentation

Documentation can be found here.

If you're looking for the old example modules...

See BFG.

The examples have been offloaded to a distinct project to minimize code and packaging issues. Database and attack capabilities have also been merged into a single binary.

Key Features

  • Protocol agnostic - If a callback can be written in Python, BruteLoops can be used to attack it
  • SQLite support - All usernames, passwords, and credentials are maintained in an SQLite database.
    • A companion utility (dbmanager.py) that creates and manages input databases accompanies BruteLoops
  • Spray and Stuffing Attacks in One Tool - BruteLoops supports both spray and stuffing attacks in the same attack logic and database, meaning that you can configure a single database and run the attack without heavy reconfiguration and confusion.
  • Guess scheduling - Each username in the SQLite database is configured with a timestamp that is updated after each authentication event. This means we can significantly reduce likelihood of locking accounts by scheduling each authentication event with precision.
  • Fine-grained configurability to avoid lockout events - Microsoft's lockout policies can be matched 1-to-1 using BruteLoop's parameters:
    • auth_threshold = Lockout Threshold
    • max_auth_jitter = Lockout Observation Window
    • Timestampes associated with each authentication event are tracked in BruteLoops' SQLite database. Each username receives a distinct timestamp to assure that authentication events are highly controlled.
  • Attack resumption - Stopping and resuming an attack is possible without worrying about losing your place in the attack or locking accounts.
  • Multiprocessing - Speed up attacks using multiprocessing! By configuring the parallel guess count, you're effectively telling BruteLoops how many usernames to guess in parallel.
  • Logging - Each authentication event can optionally logged to disk. This information can be useful during red teams by providing customers with a detailed attack timeline that can be mapped back to logged events.
  • Breakers - Breakers behave like circuit breakers. An exception can be raised x number of times before ending the attack loop. They can reset after a given period of time as well, allowing for configurations like "Exit after 6 ConnectionErrors occur".

Dependencies

BruteLoops requires Python3.7 or newer and SQLAlchemy 1.3.0, the latter of which can be obtained via pip and the requirements.txt file in this repository: python3.7 -m pip install -r requirements.txt

Installation

git clone https://github.com/arch4ngel/bruteloops
cd bruteloops
python3 -m pip install -r requirements.txt

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bruteloops-1.0.1.tar.gz (41.7 kB view details)

Uploaded Source

Built Distribution

bruteloops-1.0.1-py3-none-any.whl (45.9 kB view details)

Uploaded Python 3

File details

Details for the file bruteloops-1.0.1.tar.gz.

File metadata

  • Download URL: bruteloops-1.0.1.tar.gz
  • Upload date:
  • Size: 41.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.16

File hashes

Hashes for bruteloops-1.0.1.tar.gz
Algorithm Hash digest
SHA256 2cac65250542c2dca78eb1c299d0e72693d562dc3338e8e99133fd272f8b151c
MD5 870123b2e9db0bb6948d4a7167cadd86
BLAKE2b-256 de145e39ec5f07108e33515c12871fca5be23d6126dbf413696a6bd250d4a3d0

See more details on using hashes here.

File details

Details for the file bruteloops-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: bruteloops-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 45.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.16

File hashes

Hashes for bruteloops-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 22bfd72b77af8cee6e9bc3364cdfb57510824a619a8526e441e2c3ff7730cb7f
MD5 d42197bc33fdd5cb095f6f222fbea6c8
BLAKE2b-256 550ea47bde9428670aa0f19a80771448c1c2ce023ef995e42219ef07f854cf85

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page