You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
hashcat/tools/test_modules
mhasbini 7148aa6706
Add unit tests for several modes:
5 years ago
..
README.md
m00000.pm
m00010.pm
m00011.pm Fix Joomla salt length 5 years ago
m00012.pm
m00020.pm
m00021.pm
m00022.pm
m00023.pm
m00030.pm
m00040.pm
m00050.pm
m00060.pm
m00100.pm
m00101.pm
m00110.pm
m00111.pm
m00112.pm
m00120.pm
m00121.pm
m00122.pm
m00124.pm Add -m 124 unit test 5 years ago
m00125.pm
m00130.pm
m00131.pm
m00132.pm
m00133.pm
m00140.pm
m00141.pm
m00150.pm
m00160.pm
m00200.pm
m00300.pm
m00400.pm
m00500.pm
m00600.pm
m00900.pm
m01000.pm
m01100.pm Disable combinator constraint in -m 1100 5 years ago
m01300.pm
m01400.pm
m01410.pm Add unit test for -m 1410 -m 1420 -m ... 5 years ago
m01411.pm Remove debug lines from -m 1411 unit test 5 years ago
m01420.pm Add unit test for -m 1410 -m 1420 -m ... 5 years ago
m01421.pm Add unit tests for -m 1421 -m 1441 -m 1450 -m 1460 -m 1711 5 years ago
m01430.pm Add unit test for -m 1410 -m 1420 -m ... 5 years ago
m01440.pm Add unit test for -m 1410 -m 1420 -m ... 5 years ago
m01441.pm Add unit tests for -m 1421 -m 1441 -m 1450 -m 1460 -m 1711 5 years ago
m01450.pm Add unit tests for -m 1421 -m 1441 -m 1450 -m 1460 -m 1711 5 years ago
m01460.pm Add unit tests for -m 1421 -m 1441 -m 1450 -m 1460 -m 1711 5 years ago
m01500.pm
m01600.pm
m01700.pm
m01710.pm Add unit test for -m 1410 -m 1420 -m ... 5 years ago
m01711.pm Add unit tests for -m 1421 -m 1441 -m 1450 -m 1460 -m 1711 5 years ago
m01720.pm Add unit test for -m 1410 -m 1420 -m ... 5 years ago
m01722.pm Add -m 1722 unit test 5 years ago
m01730.pm Add unit test for -m 1410 -m 1420 -m ... 5 years ago
m01740.pm Add unit test for -m 1410 -m 1420 -m ... 5 years ago
m01750.pm Add unit tests for several modes: 5 years ago
m01760.pm Add unit tests for several modes: 5 years ago
m01800.pm
m02100.pm Add unit tests for several modes: 5 years ago
m02400.pm
m02410.pm Add unit tests for several modes: 5 years ago
m02500.pm
m02600.pm Add -m 2600 unit test 5 years ago
m02611.pm Add unit tests for several modes: 5 years ago
m02612.pm Add unit tests for several modes: 5 years ago
m02711.pm Add unit tests for several modes: 5 years ago
m02811.pm Add unit tests for several modes: 5 years ago
m03000.pm
m03100.pm Add unit tests for several modes: 5 years ago
m03200.pm
m03710.pm Add unit tests for modes: 3710, 3711, 4521 & 4522 5 years ago
m03711.pm Add unit tests for modes: 3710, 3711, 4521 & 4522 5 years ago
m03800.pm Add unit test for -m 3800 and -m 3910 5 years ago
m03910.pm Add unit test for -m 3800 and -m 3910 5 years ago
m04010.pm Add -m 4010 & -m 4110 unit tests 5 years ago
m04110.pm Add -m 4010 & -m 4110 unit tests 5 years ago
m04300.pm Add unit test for -m 1410 -m 1420 -m ... 5 years ago
m04400.pm Add unit test for -m 1410 -m 1420 -m ... 5 years ago
m04500.pm Add unit test for -m 1410 -m 1420 -m ... 5 years ago
m04520.pm Add unit test for -m 1410 -m 1420 -m ... 5 years ago
m04521.pm Add unit tests for modes: 3710, 3711, 4521 & 4522 5 years ago
m04522.pm Add unit tests for modes: 3710, 3711, 4521 & 4522 5 years ago
m04700.pm Add unit test for -m 1410 -m 1420 -m ... 5 years ago
m04900.pm Add unit tests for several modes: 5 years ago
m05100.pm
m05300.pm Add unit tests for several modes: 5 years ago
m05400.pm Add unit tests for several modes: 5 years ago
m05500.pm Add unit test for -m 5500 6 years ago
m05600.pm
m05700.pm Add unit tests for several modes: 5 years ago
m05800.pm Add unit tests for several modes: 5 years ago
m06000.pm Add unit tests for several modes: 5 years ago
m06100.pm Add unit tests for several modes: 5 years ago
m06300.pm
m06400.pm Add unit tests for several modes: 5 years ago
m06500.pm Add unit tests for several modes: 5 years ago
m07100.pm
m07500.pm
m08500.pm Add some more modules converted 5 years ago
m10800.pm
m11500.pm Fix salt encoding 6 years ago
m11600.pm Add module and unit test for -m 11600 6 years ago
m12000.pm Fixed length check for raw PBKDF2 modules 5 years ago
m12400.pm Add some more modules converted 5 years ago
m13000.pm Add module and unit test for -m 13000 6 years ago
m13100.pm
m14000.pm
m14100.pm
m15300.pm
m15900.pm
m16800.pm
m17300.pm
m17400.pm
m17500.pm
m17600.pm
m17700.pm
m17800.pm
m17900.pm
m18000.pm
m18100.pm Add unit test for -m 18100 6 years ago
m18200.pm
m18400.pm
m18500.pm
m18600.pm

README.md

Hashcat test modules

Each module provides the functions module_constraints, module_generate_hash and module_verify_hash.

  • The module_constraints function should return the minimum and maximum length of the password, salt and the combination of password and salt in following order: password (pure), salt (pure), password (optimized), salt (optimized) and combination (optimized). Each pair should be set to -1 if the hash mode is not supporting the appropriate field. For example, if a hash-mode does not support a salt, it should be set to -1. The last field (combination) is important if the the password and the salt is stored in the same buffer in the kernel (typically raw hashes only).
  • The first parameter to module_generate_hash is the password, which can be either in ASCII or binary (packed) form. The second parameter is the salt *which can be undefined for unsalted hash modes).
  • The module_verify_hash function accepts a line from the cracks file, without the newline characters.

During single and passthrough tests the module_generate_hash function must provide random values (e.g. salt) for hash generation if necessary. The test.pl script offers a few handy functions like random_hex_string, random_numeric_string and random_bytes. You can implement your own salt generation functions, if your mode has specific requirements.

During verify tests the module_verify_hash function must parse the hash:password line and calculate a hash by passing all necessary data to module_generate_hash. How you pass it is up to you, as long as the first parameter is the password.

Important: You have to call pack_if_HEX_notation as soon as you have parsed the password, or your tests will fail on passwords in the $HEX[...] format.

If the algorithm has ambiguous hashes (e.g. partial case-insensetivity), the test module can provide an optional function module_preprocess_hashlist. It recieves a reference to the hashlist array and can unify the hashes in a way that guarantees the match with the output of module_verify_hash.

Examples

  • For the most basic test modules, see m00000.pm and m00100.pm
  • For the basic salted hash tests, see m00110.pm and m00120.pm
  • For some sligthly more complex modules with PBKDF2 and encryption, see m18400.pm and m18600.pm
  • For a test module with hashlist preprocessing and a custom salt generation algorithm, see m05600.pm

NOTE:

In order to not have double work while migrating existing code to test modules, here's a work sheet for everyone who wants to contribute. Simply put your name to reserve a particular mode here:

https://docs.google.com/spreadsheets/d/14uxfwDiq316Qad0ILavWD2eeYSVr4vn2HD58hdlL35g/edit#gid=0