1.0.2 • Published 2 years ago
ez-bruteforcer v1.0.2
ez-bruteforcer
Easy to use package for bruteforce attacks, with support for ECMAScript and CJS
Table of contents
Import
Import with CommonJS...
const bruteforce = require("ez-bruteforcer");...or with ECMAScript!
import bruteforce from "ez-bruteforcer";API Reference
getDispositionsNumber()
Calculate all the dispositions
Will calculate all the avaiable dispositions without finding them
bruteforce.getDispositionsNumber("oh!sle", 6, 1);| Parameter | Type | Description | 
|---|---|---|
| array | array \|\| string | Required. The array where you want to calculate the dispositions | 
| maxLength | number | Required. The maxium length of the password | 
| minLength | number | Optional. The minium length of the password, if null will default to 1 | 
runSync()
Find all dispositions
Will start the bruteforce attack
bruteforce.runSync({
    data: [],
    step: (value) => return false,
    finish: () => { console.log('finished') },  // Optional
    maxLength: 2,
    minLength: 1 // Optional
})This function only takes one options argument
- dataARRAY / STRING (required) - The characters list to perform the attack, you can use an array or a string.
- stepFUNCTION (required) - This function will be called every time a new iteration is found, and it will pass as argument the current iteration value. It acts as a "validator" and must always return true or false. If it returns true it will stop searching, if instead returns false it will continue to iterate.
- finishFUNCTION (optional) - This function will be called when all the iteration will be done. NOTE: It will only be executed when the script finishes the iteration, this means that if a function in the step key will return true before it finishes everything this function will not be triggered.
- maxLengthNUMBER (required) - The maxium length of the password.
- minLengthNUMBER (optional) - The minium length of the password, if not specified, will be defaulted to 1
Usage/Examples
import bruteforce from "ez-bruteforcer";
const charactersList = "oh!sle";
const secretPassword = "hello!";
bruteforce.runSync({
  data: charactersList,
  step: (attempt) => {
    console.log(`Trying password: ${attempt}`);
    if (attempt == secretPassword) {
      console.log(`> Found password: ${attempt}`);
      return true;
    } else return false;
  },
  finish: () => {
    console.log("> Nothing has been found:(");
  },
  maxLength: 6,
  minLength: 1,
});
console.log(
  "> Total possible combinations: " +
    bruteforce.getDispositionsNumber(charactersList, 6, 1)
);
/*
...
Trying password: lsllo!
Trying password: esllo!
Trying password: olllo!
Trying password: hlllo!
Trying password: !lllo!
Trying password: slllo!
Trying password: llllo!
Trying password: elllo!
Trying password: oello!
Trying password: hello!
> Found password: hello!
> Total possible combinations: 55986
*/Credits
- I "stole" the code to find the dispositions from the class "BaseN" in the package js-combinatorics to then modify it to make it work for a bruteforce attack