1
mirror of https://github.com/hashcat/hashcat synced 2025-03-01 03:23:02 +01:00
hashcat/tools/test_modules
..
2019-02-13 09:37:30 +01:00
2019-02-16 13:37:17 +01:00
2019-02-16 13:37:17 +01:00
2019-02-16 13:37:17 +01:00
2019-02-16 13:37:17 +01:00
2019-01-03 16:35:41 +01:00
2019-01-03 16:35:41 +01:00
2019-01-09 10:11:50 +01:00
2019-01-09 10:11:50 +01:00
2019-02-10 02:44:39 +02:00
2019-02-16 13:37:17 +01:00
2019-02-16 13:37:17 +01:00
2019-01-09 10:50:26 +01:00
2019-01-09 10:50:26 +01:00
2019-02-16 13:37:17 +01:00
2019-02-16 13:37:17 +01:00
2019-01-18 23:09:19 +01:00
2019-01-20 23:26:40 +01:00
2019-02-16 14:12:18 +01:00
2019-01-08 23:32:17 +01:00
2019-01-08 21:46:10 +01:00
2019-01-08 20:28:25 +01:00
2019-02-16 13:37:17 +01:00
2019-02-16 13:37:17 +01:00
2019-02-16 13:37:17 +01:00
2019-02-14 17:50:47 +01:00
2019-02-16 13:37:17 +01:00
2019-02-16 13:37:17 +01:00
2019-02-16 16:04:37 +01:00
2019-01-20 23:26:40 +01:00
2019-01-08 20:10:25 +01:00
2019-02-16 13:37:17 +01:00
2019-02-16 13:37:17 +01:00
2019-02-15 09:50:19 +01:00
2019-02-16 13:37:17 +01:00
2019-02-16 13:37:17 +01:00
2019-02-16 13:37:17 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-10 01:56:42 +02:00
2019-02-13 20:00:56 +02:00
2019-02-13 20:00:56 +02:00
2019-02-16 16:04:37 +01:00
2019-02-13 20:00:56 +02:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-10 01:54:17 +02:00
2019-02-10 01:54:17 +02:00
2019-02-15 10:26:21 +01:00
2019-02-14 01:22:16 +02:00
2019-01-18 22:56:37 +01:00
2019-02-14 01:22:16 +02:00
2019-02-14 01:22:16 +02:00
2019-01-25 17:15:53 +01:00
2019-02-14 01:22:16 +02:00
2019-02-14 01:22:16 +02:00
2019-02-14 01:22:16 +02:00
2019-02-17 08:57:51 +01:00
2019-01-20 23:26:40 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-15 20:42:33 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-15 21:13:54 +01:00
2019-02-17 15:03:44 +01:00
2019-02-17 15:10:39 +01:00
2019-02-17 15:15:55 +01:00
2019-02-17 15:24:33 +01:00
2019-02-17 15:39:34 +01:00
2019-02-17 15:44:27 +01:00
2019-02-17 15:49:57 +01:00
2019-02-17 15:54:45 +01:00
2019-02-17 16:06:55 +01:00
2019-02-17 16:11:30 +01:00
2019-01-08 22:03:07 +01:00
2019-02-17 22:48:19 +02:00
2019-02-17 22:48:19 +02:00
2019-02-17 22:48:19 +02:00
2019-02-17 22:48:19 +02:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-15 21:48:09 +02:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-15 21:48:09 +02:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-15 21:48:09 +02:00
2019-02-16 16:04:37 +01:00
2019-02-15 21:48:09 +02:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00
2019-02-16 16:04:37 +01:00

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