This repository contains RuleForge, a ML-Based Password-Mangling Rule Generator for Dictionary Attacks. It also includes additional scripts and dictionaries for experimental evaluation and a Jupyter Notebook for fine-tuning rule priorities with an evolutionary algorithm.
.
├── MDBSCAN
│ ├── MDBSCAN # Source files for MDBSCAN and DBSCAN clustering
├── dictonaries
│ ├── evolution # Dictionaries used for evolution
│ | ├── 0_training
│ | ├── 1_attack
│ | ├── 2_target
├── recovered # Passwords recovered with RuleForge rules in experiment 4.4
│ └── experiments # Dictionaries used for experiments
├── rules # Rules generated with RuleForge in experiment 4.4
├── README.md
├── poetry.lock
├── pyproject.toml
├── requirements.txt
├── RuleForge.py
├── bench_gen_times.py
├── distance_matrix_generator.py
├── mdbscan_rule_generator.py
└── rule-priority-evolution.ipynb
Before you begin, ensure you have met the following requirements:
Python: This project requires Python 3.9 or newer.
pip: This project uses pip3 for managing Python packages.
.NET SDK 7.0 Required for compiling and running (M)DSBCAN clustering.
cd MDBSCAN
dotnet build -c Release
pip3 install -r requirements.txt
Install poetry:
pip3 install poetry
Install dependencies:
poetry install
For clustering with HAC and Affinity propagation:
python3.9 RuleForge.py --wordlist <wordlist_file> --rulefile <rule_file> ( --hac | --ap )
For clustering with DBSCAN:
./MDBSCAN/MDBSCAN/bin/Release/net7.0/MDBSCAN <eps> <min_pts> <wordlist_file> | python3.9 RuleForge.py --rulefile <rule_file> --stdin
For clustering with MDBSCAN:
./MDBSCAN/MDBSCAN/bin/Release/net7.0/MDBSCAN <eps1> <eps2> <min_pts> <wordlist_file> | python3.9 RuleForge.py --rulefile <rule_file> --stdin
Generate top 100 rules from darkweb2017-top10k-m.txt using hac clustering method with distance_threshold parameter set to 2:
python3.9 RuleForge.py --wordlist dictionaries/experiments/darkweb2017-top10k-m.txt --rulefile darkweb_rules.rule --hac --distance_threshold 2 --most_frequent 100
Generate rules from darkweb2017-top10k-m.txt using MDBSCAN clustering method with parameters esp1 set to 1, esp2 set to 0.25 and min_pts set to 3:
./MDBSCAN/MDBSCAN/bin/Release/net7.0/MDBSCAN 1 0.25 3 dictionaries/experiments/darkweb2017-top10k-m.txt | python3.9 RuleForge.py --rulefile darkweb_rules.rule --stdin
--wordlist <wordlist_file>
: Path to the wordlist file. This is the input wordlist for rule generation.--rulefile <rule_file>
: Path to the output file where the generated rules will be saved.--representative (combo | levenshtein | substring)
: Method for selecting a representative.
--rule_priority <rule_priority_file>
: Path to the priority rule file, for sorting or prioritizing rules.--most_frequent <number_of_rules>
: Creates a file with the specified number of most frequent rules.--distance_matrix_precomputed
: Use precomputed distance matrix
DBSCAN
:<eps>
: The maximum distance between two samples for one to be considered as in the neighborhood of the other.<min_pts>
: The number of samples in a neighborhood for a point to be considered as a core point.
MDBSCAN
:<eps1>
: The maximum distance between two samples for one to be considered as in the neighborhood of the other.<eps1>
: Jaro-winkler distance for refining clusters.<min_pts>
: The number of samples in a neighborhood for a point to be considered as a core point.
--hac
: Use hierarchical agglomerative clustering algorithm.--distance_threshold <value>
: The linkage distance threshold at or above which clusters will not be merged.
--ap
: Use affinity propagation clustering algorithm.--damping <value>
: Damping factor between 0.5 and 1.--convergence_iter <value>
: Number of iterations to wait for convergence.
bench_gen_times.py
: Benchmarking rule-generation time for MDBSCAN, DBSCAN, HAC and AP clustering methodsrule-priority-evolution.ipynb
: Rule priority evolution jupyter notebookdistance_matrix_generator.py:
Generates distance matrices from all .txt files in specified directorymdbscan_rule_generator.py:
Generates password mangling rules. Rule creation algorithm is based on the research paper Li, Shunbin, et al. “Mangling rules generation with density-based clustering for password guessing.”
RuleForge and related sripts are distributed under the MIT license (see License.txt for more information.). The authors of these codes are Radek Hranicky, Lucia Sirova, Viktor Rucky from Brno University of Technology, Faculty of Information Technolgy, Czech Republic.
Note:
- The MDBSCAN clustering was implemented, to the best of our efforts, according to the research paper: Li, Shunbin, et al. "Mangling rules generation with density-based clustering for password guessing." IEEE Transactions on Dependable and Secure Computing (2022).
- The implementations of SymSpell fuzzy hashing, Jaro-Winkler distance calculation, and files inside
MDBSCAN/MDBSCAN/SoftWx.Match
have been adopted from their authors who also released them under the MIT License. Licensing details are available in the files' headers.