1
0
mirror of https://github.com/hashcat/hashcat.git synced 2024-12-23 07:08:19 +00:00
hashcat/tools/test_modules
2022-06-29 18:15:48 +02:00
..
m00000.pm Fixed maximum password length limit which was announced as 256 but actually was 255 2019-02-26 21:20:07 +01:00
m00010.pm
m00011.pm
m00012.pm
m00020.pm
m00021.pm
m00022.pm Fixed Unit Test salt-max in case of optimized kernel, with hash-type 22 and 23 2022-01-15 16:27:15 +01:00
m00023.pm Fixed Unit Test salt-max in case of optimized kernel, with hash-type 22 and 23 2022-01-15 16:27:15 +01:00
m00024.pm
m00030.pm
m00040.pm
m00050.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m00060.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m00070.pm
m00100.pm
m00101.pm
m00110.pm
m00111.pm
m00112.pm
m00120.pm
m00121.pm
m00122.pm
m00124.pm
m00125.pm
m00130.pm
m00131.pm
m00132.pm
m00133.pm
m00140.pm
m00141.pm
m00150.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m00160.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m00170.pm
m00200.pm
m00300.pm
m00400.pm
m00500.pm
m00600.pm
m00610.pm Limit password and salt length in unit test for -m 610 and -m 620 2022-05-27 17:34:08 +02:00
m00620.pm Limit password and salt length in unit test for -m 610 and -m 620 2022-05-27 17:34:08 +02:00
m00900.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m01000.pm Example of a better UTF8 to UTF16LE encoding in unit test. It allows digesting UTF8 encoded password candidates from the shell in passthrough mode 2021-05-01 12:22:07 +02:00
m01100.pm
m01300.pm
m01400.pm Fixed maximum password length limit which was announced as 256 but actually was 255 2019-02-26 21:20:07 +01:00
m01410.pm
m01411.pm minor whitespace fixes, per #2841 2021-06-21 07:47:22 -08:00
m01420.pm
m01421.pm
m01430.pm
m01440.pm
m01441.pm
m01450.pm
m01460.pm
m01470.pm
m01500.pm
m01600.pm
m01700.pm
m01710.pm
m01711.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m01720.pm
m01722.pm
m01730.pm
m01731.pm
m01740.pm Fixed maximum password length limit which was announced as 256 but actually was 255 2019-02-26 21:20:07 +01:00
m01750.pm
m01760.pm
m01770.pm
m01800.pm
m02100.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m02400.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m02410.pm
m02500.pm
m02600.pm
m02611.pm
m02612.pm
m02711.pm
m02811.pm
m03000.pm Prevent unit test of -m 3000 to generate zero hash. This confuses test.sh validator 2021-04-26 09:32:19 +02:00
m03100.pm
m03200.pm
m03500.pm
m03710.pm Fixed maximum password length limit which was announced as 256 but actually was 255 2019-02-26 21:20:07 +01:00
m03711.pm
m03800.pm
m03910.pm
m04010.pm
m04110.pm
m04300.pm
m04400.pm
m04410.pm added md5(sha1($pass).$salt) 2022-06-18 18:11:00 +02:00
m04500.pm
m04510.pm fixes #3029: cracking long salts in -m 4510/4710 2022-02-09 16:43:24 +01:00
m04520.pm
m04521.pm
m04522.pm
m04700.pm
m04710.pm fixes #3029: cracking long salts in -m 4510/4710 2022-02-09 16:43:24 +01:00
m04711.pm
m04800.pm
m04900.pm
m05000.pm
m05100.pm
m05300.pm
m05400.pm
m05500.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m05600.pm
m05700.pm
m05800.pm
m06000.pm
m06100.pm
m06300.pm
m06400.pm
m06500.pm
m06600.pm
m06700.pm
m06800.pm
m06900.pm
m07000.pm cosmetic: minor code style fixes 2020-06-13 11:19:00 +02:00
m07100.pm
m07200.pm
m07300.pm
m07400.pm
m07401.pm
m07500.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m07700.pm
m07701.pm
m07800.pm
m07801.pm
m07900.pm
m08000.pm
m08100.pm
m08200.pm
m08300.pm
m08400.pm Fixed maximum password length limit which was announced as 256 but actually was 255 2019-02-26 21:20:07 +01:00
m08500.pm
m08600.pm
m08700.pm
m08900.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m09100.pm
m09200.pm
m09300.pm cosmetic: minor code style fixes 2020-06-13 11:19:00 +02:00
m09400.pm Add -m 9600 unit test 2019-02-18 14:12:28 +01:00
m09500.pm Fixed unit tests using 'null' as padding method in Crypt::CBC but actually want to use 'none' 2021-05-11 07:15:45 +02:00
m09600.pm Fixed unit tests using 'null' as padding method in Crypt::CBC but actually want to use 'none' 2021-05-11 07:15:45 +02:00
m09700.pm
m09800.pm
m09900.pm
m10000.pm
m10100.pm Do not use next if we mean return 2019-02-19 12:50:57 +01:00
m10200.pm
m10300.pm
m10400.pm
m10500.pm Do not use next if we mean return 2019-02-19 12:50:57 +01:00
m10600.pm
m10700.pm Fixed unit tests using 'null' as padding method in Crypt::CBC but actually want to use 'none' 2021-05-11 07:15:45 +02:00
m10800.pm Fixed maximum password length limit which was announced as 256 but actually was 255 2019-02-26 21:20:07 +01:00
m10810.pm
m10820.pm
m10830.pm
m10840.pm
m10870.pm
m10900.pm
m10901.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m11000.pm
m11100.pm
m11200.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m11300.pm
m11400.pm
m11500.pm Fixed unit test initialization value for -m 11500 2021-10-01 20:16:47 +02:00
m11600.pm Add -m 11600 optimized kernel 2020-01-26 18:38:47 +01:00
m11700.pm
m11750.pm
m11760.pm
m11800.pm
m11850.pm
m11860.pm
m11900.pm
m12000.pm
m12001.pm
m12100.pm
m12200.pm
m12300.pm
m12400.pm
m12500.pm Restore maximum password length 128 for pure RAR3 kernels 2021-05-21 22:04:24 +02:00
m12600.pm
m12700.pm
m12800.pm
m12900.pm
m13000.pm
m13100.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m13200.pm
m13300.pm
m13400.pm
m13500.pm
m13600.pm tests: fixed -m 13600 = WinZip verification 2020-07-21 11:06:34 +02:00
m13800.pm
m13900.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m14000.pm
m14100.pm
m14400.pm
m14700.pm
m14800.pm
m14900.pm
m15000.pm
m15100.pm
m15200.pm minor whitespace fixes, per #2841 2021-06-21 07:47:22 -08:00
m15300.pm Prepare for DPAPI masterkey Context 3 2022-03-06 00:47:14 +01:00
m15310.pm Added hash-mode: DPAPI masterkey file v1 (context 3) 2022-03-06 00:50:46 +01:00
m15400.pm
m15500.pm
m15600.pm
m15700.pm
m15900.pm Prepare for DPAPI masterkey Context 3 2022-03-06 00:47:14 +01:00
m15910.pm DPAPI masterkey file v2 (context 3) 2022-03-06 00:55:47 +01:00
m16000.pm
m16100.pm
m16200.pm
m16300.pm
m16400.pm
m16500.pm
m16600.pm Fixed unit tests using 'null' as padding method in Crypt::CBC but actually want to use 'none' 2021-05-11 07:15:45 +02:00
m16700.pm
m16800.pm
m16900.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m17300.pm
m17400.pm
m17500.pm
m17600.pm
m17700.pm
m17800.pm
m17900.pm Fixed more constraints in unit tests 2019-02-16 16:04:37 +01:00
m18000.pm
m18100.pm
m18200.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m18300.pm
m18400.pm
m18500.pm
m18600.pm
m18700.pm
m18800.pm
m18900.pm
m19000.pm
m19100.pm
m19200.pm
m19300.pm
m19500.pm
m19600.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m19700.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m19800.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m19900.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m20011.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m20012.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m20013.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m20200.pm minor whitespace fixes, per #2841 2021-06-21 07:47:22 -08:00
m20300.pm minor whitespace fixes, per #2841 2021-06-21 07:47:22 -08:00
m20400.pm minor whitespace fixes, per #2841 2021-06-21 07:47:22 -08:00
m20500.pm
m20510.pm
m20600.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m20710.pm
m20711.pm
m20720.pm
m20800.pm
m20900.pm
m21000.pm
m21100.pm
m21200.pm
m21300.pm
m21400.pm
m21420.pm removed unused printf from 21420 test module 2022-02-13 19:03:24 +01:00
m21500.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m21501.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m21600.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m21700.pm
m21800.pm
m22000.pm
m22100.pm
m22200.pm
m22300.pm
m22301.pm
m22400.pm AES Crypt Plugin: Replaced naive with true UTF8 to UTF16 conversion, reduced max password length to 128 and improved performance 2021-05-21 22:12:32 +02:00
m22500.pm
m22600.pm
m22700.pm
m22911.pm minor: update list of perl modules for unit tests 2020-08-26 12:41:25 +02:00
m22921.pm
m22931.pm
m22941.pm
m22951.pm
m23001.pm
m23002.pm
m23003.pm
m23100.pm Fixed unit tests using 'null' as padding method in Crypt::CBC but actually want to use 'none' 2021-05-11 07:15:45 +02:00
m23200.pm
m23300.pm Fixed unit tests using 'null' as padding method in Crypt::CBC but actually want to use 'none' 2021-05-11 07:15:45 +02:00
m23400.pm Add parameter for second iteration count 2022-02-28 23:16:12 +01:00
m23500.pm
m23600.pm
m23700.pm Restore maximum password length 128 for pure RAR3 kernels 2021-05-21 22:04:24 +02:00
m23900.pm Added -m 23900 = BestCrypt v3 Volume Encryption 2020-09-26 16:38:51 +02:00
m24100.pm
m24200.pm Added mongodb-scram ServerKey (-m 24100 for SHA1, -m 24200 for SHA256) 2020-10-04 16:42:19 +02:00
m24300.pm
m24410.pm
m24420.pm
m24500.pm
m24600.pm
m24700.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m24800.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m24900.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m25000.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m25100.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m25200.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m25300.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m25400.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m25500.pm Unit-Tests: Added missing unit-test for Stargazer Stellar Wallet XLM 2021-06-10 09:02:26 +02:00
m25600.pm Rename -m 3201 to -m 25600 2021-05-17 13:23:50 +02:00
m25700.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m25800.pm Rename -m 3202 to -m 25800 2021-05-18 19:25:47 +02:00
m25900.pm minor whitespace fixes, per #2841 2021-06-21 07:47:22 -08:00
m26000.pm Remove some debugging code from tools/test_modules/m26000.pm 2021-04-17 21:28:20 +02:00
m26100.pm Added new hash-modes Mozilla key3.db and key4.db 2021-04-17 21:24:27 +02:00
m26200.pm fixes #2840: minor code style changes for OpenEdge tests 2021-06-22 10:40:24 +02:00
m26300.pm Renamed -m 7010 to -m 26300 2021-06-08 11:12:54 +02:00
m26401.pm Added hash-mode: AES-128/192/256-ECB NOKDF 2021-06-26 17:12:10 +02:00
m26402.pm Added hash-mode: AES-128/192/256-ECB NOKDF 2021-06-26 17:12:10 +02:00
m26403.pm Added hash-mode: AES-128/192/256-ECB NOKDF 2021-06-26 17:12:10 +02:00
m26500.pm Added hash-mode: iPhone passcode (UID key + System Keybag) 2021-07-03 19:03:06 +02:00
m26600.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m26700.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m26800.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m26900.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m27000.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m27100.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m27200.pm Fix errors and make recommended changes, set pw_max to 9 for opti kernel 2021-08-06 09:58:19 -04:00
m27300.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m27400.pm move to 27400, fix unit test 2021-08-10 16:35:15 +02:00
m27500.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m27600.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m27700.pm fixes #2674: added -m 27700 = MultiBit Classic .wallet (scrypt) 2021-09-06 19:54:22 +02:00
m27800.pm add tests for -m 27800 = MurmurHash 3 2022-06-11 11:15:03 +02:00
m27900.pm Added missing unit-test for -m 27900 2021-10-02 09:57:40 +02:00
m28000.pm Added hash-mode: CRC64Jones 2021-10-09 11:43:04 +02:00
m28100.pm tests: get rid of wrong modules from -m 28100 2021-11-29 17:12:56 +01:00
m28200.pm remove unnecessary perl modules from Exodus tests 2022-01-18 16:20:45 +01:00
m28300.pm tests: cleanup and module deps fix 2022-01-30 10:35:51 +01:00
m28400.pm Added kernel, module and unit-test for hash-mode 28400: bcryptsha512 2022-03-02 12:32:01 +01:00
m28501.pm Add -m 28503/28504 = Bitcoin WIF, P2WSH/bech32/segwit address 2022-06-20 15:25:34 +02:00
m28502.pm Add -m 28503/28504 = Bitcoin WIF, P2WSH/bech32/segwit address 2022-06-20 15:25:34 +02:00
m28503.pm Add -m 28503/28504 = Bitcoin WIF, P2WSH/bech32/segwit address 2022-06-20 15:25:34 +02:00
m28504.pm Add -m 28503/28504 = Bitcoin WIF, P2WSH/bech32/segwit address 2022-06-20 15:25:34 +02:00
m28505.pm Add -m 28505/28506, Bitcoin WIF, P2SH(P2WPKH)/compat address 2022-06-29 18:15:48 +02:00
m28506.pm Add -m 28505/28506, Bitcoin WIF, P2SH(P2WPKH)/compat address 2022-06-29 18:15:48 +02:00
m28600.pm changed mode number to 28600 2022-01-20 19:31:09 +01:00
m28700.pm cleanup: remove spaces at the end of lines 2022-06-20 15:19:01 +02:00
m28800.pm Added hash-mode: Kerberos 5, etype 17, DB 2022-03-05 12:59:14 +01:00
m28900.pm Added hash-mode: Kerberos 5, etype 18, DB 2022-03-05 12:59:38 +01:00
m29000.pm add unit tests for -m 29000 2022-06-08 15:44:14 +02:00
m29100.pm fix -m 29100 unit test dependencies 2022-06-08 16:05:34 +02:00
m29200.pm radmin 3: remove whitespace, add credits to tests 2022-05-30 16:59:30 +02:00
README.md minor whitespace fixes 2021-06-22 08:55:44 +02: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 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