Skip to main content

Customizable wordlist generator with advanced pattern.

This project has been archived.

The maintainers of this project have marked this project as archived. No new releases are expected.

Project description


fuse
Pattern-based wordlist generation tool

Installation    •    Usage    •    Contributing

demo

Installation

[!NOTE]
It is recommended to install using pipx or pip for the PyPI version.

Method Notes
pipx install fuse-generator pip may be used in place of pipx
git clone https://github.com/pwnfo/fuse.git && cd fuse && pip install . Clone and install directly from GitHub

General usage

To generate a wordlist from a simple expression:

fuse '/l{2,4}'

To combine files with generators:

fuse '^:^' names.txt pass.txt

Outputs can be manipulated, filtered, and saved.

Powerful pattern-based wordlist generation tool.

General Options:
  -h, --help            show this help message and exit
  -v, --version         show version information and exit
  -q, --quiet           suppress non-essential output
  -n, --non-interactive
                        skip the confirmation prompt before execution

Generation Options:
  -d, --delimiter <string>
                        string inserted between generated entries
  -b, --write-buffer <size>
                        output buffer size
  -w, --workers <1-64>  number of worker processes (default: 1)
  -F, --filter <regex>  filter generated words with a regular expression
  -k, --flush-threshold <size>
                        flush output after reaching this byte threshold (default: 512KB)

Input Options:
  -f, --file <path>     load expressions from file
  -S, --start <word>    start writing output from <word>
  -E, --end <word>      stop writing output at <word>

Output Options:
  -o, --output <path>   write output to a file
  -z, --compress <format>
                        compress output (supported: gzip, bzip2, lzma)
  -l, --compresslevel <level>
                        compression level for the selected format

Expression basics

  • Literal characters produce themselves.
  • Built-in classes and bracketed classes [...] produce one item per position.
  • Concatenation combines positions: each position picks one value from its token and concatenates.

Example:

$ fuse '/l{2,3}'
# output: aa, ab, ac, ..., ZY, ZZ

Character classes

Symbol Meaning
/l letters (a–z, A–Z)
/a lowercase letters (a–z)
/A uppercase letters (A–Z)
/d digits (0–9)
/D non-zero digits (1–9)
/h lowercase hexadecimal (0–9, a–f)
/H uppercase hexadecimal (0–9, A–F)
/s space
/o octal digits (0–7)
/p special characters
/b newline (\n)

Example: /l/l generates all two-letter combinations (upper and lower case).

Custom classes and unions

  • [abc] selects one character from a, b, or c.
  • Use | to separate full-word alternatives (each treated as a multi-character token):
    • [admin|root|123] inserts admin OR root OR 123 at that point.

Quantifiers

  • {N} — repeat exactly N times
  • {min,max} — repeat between min and max times (inclusive)
  • ? — optional (0 or 1 time)

Examples:

$ fuse '[XYZ]{3}'         # XXX, XXY, ..., ZZZ
$ fuse '[XYZ]{2,5}'       # XY, XZ, ..., XYZXY
$ fuse 'Ryan?/d'          # Rya0, Rya1, ..., Ryan9
$ fuse '[XYZ]?Ryan'       # Ryan, XRyan, YRyan, ZRyan

Numeric ranges

  • #[1-10] → generates 1,2,3,4,5,6,7,8,9,10
  • #[1-10:2] → generates 1,3,5,7,9
  • #[2-10:2] → generates 2,4,6,8,10

These numeric ranges can be used in any position of an expression.

Files and placeholders

Use ^ in an expression as a placeholder for the next file argument. Each ^ consumes one file and iterates over its lines:

$ fuse '^/d' names.txt
# output: Bob0, Bob1, ..., Ana0, Ana1, ...

$ fuse '^-^' names.txt years.txt
# output: Bob-1990, Ana-1991, Ryan-1992, ...

Prefix a filename with // to treat it as an inline expression instead of a file path.

Value bindings

Use <@name=expr> to evaluate an expression once per output line and store it, then reuse it with <@name>. Unlike concatenation, this introduces a dependency, so no cartesian product is created between the definition and its references.

$ fuse '<@d=/d>-<@d>'
# output: 0-0, 1-1, ..., 9-9

$ fuse '<@x=^>:<@x>' words.txt
# output: foo:foo, bar:bar, ...

$ fuse '<@n=/d{2}>_<@n>'
# output: 00_00, 01_01, ..., 99_99

Compression

Fuse supports on-the-fly compression when writing output files.

# gzip (fast, balanced)
fuse '/l{5}' -z gzip -o wordlist.txt.gz

# lzma (best compression)
fuse '/l{5}' -z lzma -o wordlist.txt.xz

# bzip2 (middle ground)
fuse '/l{5}' -z bzip2 -o wordlist.txt.bz2

Escaping special characters

Use \ to escape special characters.

$ fuse '\/d/d'
# output: /d/0, /d/1, ..., /d/9

Contributing

We welcome contributions to Fuse! Whether it's adding new features, improving documentation, or fixing bugs, your help is appreciated. Feel free to open an issue or submit a pull request on our GitHub repository at pwnfo/fuse.

Star History

Fuse Project Star History Chart

License

MIT © Ryan R. <pwnfo@proton.me>

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

fuse_generator-6.0.0.tar.gz (24.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fuse_generator-6.0.0-py3-none-any.whl (28.2 kB view details)

Uploaded Python 3

File details

Details for the file fuse_generator-6.0.0.tar.gz.

File metadata

  • Download URL: fuse_generator-6.0.0.tar.gz
  • Upload date:
  • Size: 24.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.2 CPython/3.13.5 Linux/6.12.85+deb13-amd64

File hashes

Hashes for fuse_generator-6.0.0.tar.gz
Algorithm Hash digest
SHA256 d14af84153eeb417d62cb42eedfd7cee048197693ac6664eaa311f4bc2f44c62
MD5 5297931a1a784f2cf7c61131594a223c
BLAKE2b-256 7a4e61e35a6b5a13b047a7894c48343e7f6cbeef31424a28019c5c907f403d81

See more details on using hashes here.

File details

Details for the file fuse_generator-6.0.0-py3-none-any.whl.

File metadata

  • Download URL: fuse_generator-6.0.0-py3-none-any.whl
  • Upload date:
  • Size: 28.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.2 CPython/3.13.5 Linux/6.12.85+deb13-amd64

File hashes

Hashes for fuse_generator-6.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2d5e2ae0cd54aeb77cf07ddbb23a3d4173f539505f9ed9d1f201a25d66bdfcb5
MD5 4543b85eb99f6c84d0330377388db834
BLAKE2b-256 1f7dbddd936726bcba61b2ff49a62a41d8f604e74715aec9fe223f3676009140

See more details on using hashes here.

Supported by

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