mirror of
https://github.com/hashcat/hashcat.git
synced 2024-12-22 22:58:30 +00:00
Get rid of more log_info() in hashcat()
This commit is contained in:
parent
81650dcc46
commit
27887bf9ce
@ -33,7 +33,7 @@ void potfile_show_request (hashcat_ctx_t *hashcat_ctx, char *input_buf, int
|
|||||||
void potfile_left_request (hashcat_ctx_t *hashcat_ctx, char *input_buf, int input_len, hash_t *hashes_buf, int (*sort_by_pot) (const void *, const void *, void *));
|
void potfile_left_request (hashcat_ctx_t *hashcat_ctx, char *input_buf, int input_len, hash_t *hashes_buf, int (*sort_by_pot) (const void *, const void *, void *));
|
||||||
void potfile_show_request_lm (hashcat_ctx_t *hashcat_ctx, char *input_buf, int input_len, hash_t *hash_left, hash_t *hash_right, int (*sort_by_pot) (const void *, const void *, void *));
|
void potfile_show_request_lm (hashcat_ctx_t *hashcat_ctx, char *input_buf, int input_len, hash_t *hash_left, hash_t *hash_right, int (*sort_by_pot) (const void *, const void *, void *));
|
||||||
void potfile_left_request_lm (hashcat_ctx_t *hashcat_ctx, char *input_buf, int input_len, hash_t *hash_left, hash_t *hash_right, int (*sort_by_pot) (const void *, const void *, void *));
|
void potfile_left_request_lm (hashcat_ctx_t *hashcat_ctx, char *input_buf, int input_len, hash_t *hash_left, hash_t *hash_right, int (*sort_by_pot) (const void *, const void *, void *));
|
||||||
int potfile_remove_parse (hashcat_ctx_t *hashcat_ctx);
|
void potfile_remove_parse (hashcat_ctx_t *hashcat_ctx);
|
||||||
void potfile_destroy (hashcat_ctx_t *hashcat_ctx);
|
void potfile_destroy (hashcat_ctx_t *hashcat_ctx);
|
||||||
|
|
||||||
#endif // _POTFILE_H
|
#endif // _POTFILE_H
|
||||||
|
@ -91,16 +91,24 @@ typedef enum event_identifier
|
|||||||
EVENT_LOGFILE_SUB_FINALIZE = 0x00000024,
|
EVENT_LOGFILE_SUB_FINALIZE = 0x00000024,
|
||||||
EVENT_OUTERLOOP_STARTING = 0x00000031,
|
EVENT_OUTERLOOP_STARTING = 0x00000031,
|
||||||
EVENT_OUTERLOOP_FINISHED = 0x00000032,
|
EVENT_OUTERLOOP_FINISHED = 0x00000032,
|
||||||
|
EVENT_OUTERLOOP_MAINSCREEN = 0x00000033,
|
||||||
|
EVENT_OUTERLOOP_WEAK_HASH = 0x00000034,
|
||||||
EVENT_INNERLOOP1_STARTING = 0x00000041,
|
EVENT_INNERLOOP1_STARTING = 0x00000041,
|
||||||
EVENT_INNERLOOP1_FINISHED = 0x00000042,
|
EVENT_INNERLOOP1_FINISHED = 0x00000042,
|
||||||
EVENT_INNERLOOP2_STARTING = 0x00000051,
|
EVENT_INNERLOOP2_STARTING = 0x00000051,
|
||||||
EVENT_INNERLOOP2_FINISHED = 0x00000052,
|
EVENT_INNERLOOP2_FINISHED = 0x00000052,
|
||||||
|
EVENT_CALCULATED_WORDS_BASE = 0x00000059,
|
||||||
EVENT_AUTOTUNE_STARTING = 0x00000053,
|
EVENT_AUTOTUNE_STARTING = 0x00000053,
|
||||||
EVENT_AUTOTUNE_FINISHED = 0x00000054,
|
EVENT_AUTOTUNE_FINISHED = 0x00000054,
|
||||||
EVENT_CRACKER_STARTING = 0x00000055,
|
EVENT_CRACKER_STARTING = 0x00000055,
|
||||||
EVENT_CRACKER_FINISHED = 0x00000056,
|
EVENT_CRACKER_FINISHED = 0x00000056,
|
||||||
EVENT_CRACKER_FINAL_STATS = 0x00000057,
|
EVENT_CRACKER_FINAL_STATS = 0x00000057,
|
||||||
EVENT_CRACKER_HASH_CRACKED = 0x00000058,
|
EVENT_CRACKER_HASH_CRACKED = 0x00000058,
|
||||||
|
EVENT_POTFILE_REMOVE_PARSE = 0x00000061,
|
||||||
|
EVENT_POTFILE_NUM_CRACKED = 0x00000062,
|
||||||
|
EVENT_POTFILE_ALL_CRACKED = 0x00000063,
|
||||||
|
EVENT_OPENCL_SESSION_PRE = 0x00000071,
|
||||||
|
EVENT_OPENCL_SESSION_POST = 0x00000072,
|
||||||
|
|
||||||
// there will be much more event types soon
|
// there will be much more event types soon
|
||||||
|
|
||||||
@ -499,6 +507,7 @@ typedef struct hashes
|
|||||||
|
|
||||||
void *esalts_buf;
|
void *esalts_buf;
|
||||||
|
|
||||||
|
u32 hashes_cnt_orig;
|
||||||
u32 hashes_cnt;
|
u32 hashes_cnt;
|
||||||
hash_t *hashes_buf;
|
hash_t *hashes_buf;
|
||||||
|
|
||||||
|
146
src/hashcat.c
146
src/hashcat.c
@ -188,12 +188,9 @@ static int inner2_loop (hashcat_ctx_t *hashcat_ctx)
|
|||||||
|
|
||||||
status_ctx->words_base = status_ctx->words_cnt / user_options_extra_amplifier (hashcat_ctx);
|
status_ctx->words_base = status_ctx->words_cnt / user_options_extra_amplifier (hashcat_ctx);
|
||||||
|
|
||||||
if (user_options->keyspace == true)
|
EVENT_SEND (EVENT_CALCULATED_WORDS_BASE);
|
||||||
{
|
|
||||||
log_info ("%" PRIu64 "", status_ctx->words_base);
|
|
||||||
|
|
||||||
return 0;
|
if (user_options->keyspace == true) return 0;
|
||||||
}
|
|
||||||
|
|
||||||
// restore stuff
|
// restore stuff
|
||||||
|
|
||||||
@ -427,10 +424,7 @@ static int inner1_loop (hashcat_ctx_t *hashcat_ctx)
|
|||||||
|
|
||||||
static int outer_loop (hashcat_ctx_t *hashcat_ctx)
|
static int outer_loop (hashcat_ctx_t *hashcat_ctx)
|
||||||
{
|
{
|
||||||
bitmap_ctx_t *bitmap_ctx = hashcat_ctx->bitmap_ctx;
|
|
||||||
hashconfig_t *hashconfig = hashcat_ctx->hashconfig;
|
|
||||||
hashes_t *hashes = hashcat_ctx->hashes;
|
hashes_t *hashes = hashcat_ctx->hashes;
|
||||||
hwmon_ctx_t *hwmon_ctx = hashcat_ctx->hwmon_ctx;
|
|
||||||
mask_ctx_t *mask_ctx = hashcat_ctx->mask_ctx;
|
mask_ctx_t *mask_ctx = hashcat_ctx->mask_ctx;
|
||||||
opencl_ctx_t *opencl_ctx = hashcat_ctx->opencl_ctx;
|
opencl_ctx_t *opencl_ctx = hashcat_ctx->opencl_ctx;
|
||||||
outcheck_ctx_t *outcheck_ctx = hashcat_ctx->outcheck_ctx;
|
outcheck_ctx_t *outcheck_ctx = hashcat_ctx->outcheck_ctx;
|
||||||
@ -506,23 +500,21 @@ static int outer_loop (hashcat_ctx_t *hashcat_ctx)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Potfile removes
|
* potfile removes
|
||||||
*/
|
*/
|
||||||
|
|
||||||
int potfile_remove_cracks = 0;
|
|
||||||
|
|
||||||
if (user_options->potfile_disable == 0)
|
if (user_options->potfile_disable == 0)
|
||||||
{
|
{
|
||||||
if (user_options->quiet == false) log_info_nn ("Comparing hashes with potfile entries...");
|
EVENT_SEND (EVENT_POTFILE_REMOVE_PARSE);
|
||||||
|
|
||||||
potfile_remove_cracks = potfile_remove_parse (hashcat_ctx);
|
potfile_remove_parse (hashcat_ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* load hashes, stage 2, remove duplicates, build base structure
|
* load hashes, stage 2, remove duplicates, build base structure
|
||||||
*/
|
*/
|
||||||
|
|
||||||
const u32 hashes_cnt_orig = hashes->hashes_cnt;
|
hashes->hashes_cnt_orig = hashes->hashes_cnt;
|
||||||
|
|
||||||
const int rc_hashes_init_stage2 = hashes_init_stage2 (hashcat_ctx);
|
const int rc_hashes_init_stage2 = hashes_init_stage2 (hashcat_ctx);
|
||||||
|
|
||||||
@ -534,13 +526,7 @@ static int outer_loop (hashcat_ctx_t *hashcat_ctx)
|
|||||||
|
|
||||||
if (status_ctx->devices_status == STATUS_CRACKED)
|
if (status_ctx->devices_status == STATUS_CRACKED)
|
||||||
{
|
{
|
||||||
if (user_options->quiet == false)
|
EVENT_SEND (EVENT_POTFILE_ALL_CRACKED);
|
||||||
{
|
|
||||||
log_info ("INFO: All hashes found in potfile! You can use --show to display them.");
|
|
||||||
log_info ("");
|
|
||||||
log_info ("INFO: No more hashes left to crack, exiting...");
|
|
||||||
log_info ("");
|
|
||||||
}
|
|
||||||
|
|
||||||
hashes_destroy (hashcat_ctx);
|
hashes_destroy (hashcat_ctx);
|
||||||
|
|
||||||
@ -640,107 +626,20 @@ static int outer_loop (hashcat_ctx_t *hashcat_ctx)
|
|||||||
if (rc_status_init == -1) return -1;
|
if (rc_status_init == -1) return -1;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* enable custom signal handler(s)
|
* main screen
|
||||||
* currently disabled, because man page says:
|
|
||||||
* The effects of signal() in a multithreaded process are unspecified.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
EVENT_SEND (EVENT_OUTERLOOP_MAINSCREEN);
|
||||||
if (user_options->benchmark == false)
|
|
||||||
{
|
|
||||||
hc_signal (sigHandler_default);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
hc_signal (sigHandler_benchmark);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* inform the user
|
* inform the user
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (user_options->quiet == false)
|
EVENT_SEND (EVENT_OPENCL_SESSION_PRE);
|
||||||
{
|
|
||||||
log_info ("Hashes: %u digests; %u unique digests, %u unique salts", hashes_cnt_orig, hashes->digests_cnt, hashes->salts_cnt);
|
|
||||||
|
|
||||||
log_info ("Bitmaps: %u bits, %u entries, 0x%08x mask, %u bytes, %u/%u rotates", bitmap_ctx->bitmap_bits, bitmap_ctx->bitmap_nums, bitmap_ctx->bitmap_mask, bitmap_ctx->bitmap_size, bitmap_ctx->bitmap_shift1, bitmap_ctx->bitmap_shift2);
|
|
||||||
|
|
||||||
if (user_options->attack_mode == ATTACK_MODE_STRAIGHT)
|
|
||||||
{
|
|
||||||
log_info ("Rules: %u", straight_ctx->kernel_rules_cnt);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (user_options->quiet == false) log_info ("");
|
|
||||||
|
|
||||||
if (hashconfig->opti_type)
|
|
||||||
{
|
|
||||||
log_info ("Applicable Optimizers:");
|
|
||||||
|
|
||||||
for (u32 i = 0; i < 32; i++)
|
|
||||||
{
|
|
||||||
const u32 opti_bit = 1u << i;
|
|
||||||
|
|
||||||
if (hashconfig->opti_type & opti_bit) log_info ("* %s", stroptitype (opti_bit));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (user_options->quiet == false) log_info ("");
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Watchdog and Temperature balance
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (hwmon_ctx->enabled == false && user_options->gpu_temp_disable == false)
|
|
||||||
{
|
|
||||||
log_info ("Watchdog: Hardware Monitoring Interface not found on your system");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hwmon_ctx->enabled == true && user_options->gpu_temp_abort > 0)
|
|
||||||
{
|
|
||||||
log_info ("Watchdog: Temperature abort trigger set to %uc", user_options->gpu_temp_abort);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
log_info ("Watchdog: Temperature abort trigger disabled");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hwmon_ctx->enabled == true && user_options->gpu_temp_retain > 0)
|
|
||||||
{
|
|
||||||
log_info ("Watchdog: Temperature retain trigger set to %uc", user_options->gpu_temp_retain);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
log_info ("Watchdog: Temperature retain trigger disabled");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (user_options->quiet == false) log_info ("");
|
|
||||||
}
|
|
||||||
|
|
||||||
#if defined (DEBUG)
|
|
||||||
if (user_options->benchmark == true) log_info ("Hashmode: %d", hashconfig->hash_mode);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (user_options->quiet == false) log_info_nn ("Initializing device kernels and memory...");
|
|
||||||
|
|
||||||
opencl_session_begin (hashcat_ctx);
|
opencl_session_begin (hashcat_ctx);
|
||||||
|
|
||||||
if (user_options->quiet == false) log_info_nn ("");
|
EVENT_SEND (EVENT_OPENCL_SESSION_POST);
|
||||||
|
|
||||||
/**
|
|
||||||
* In benchmark-mode, inform user which algorithm is checked
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (user_options->benchmark == true)
|
|
||||||
{
|
|
||||||
if (user_options->machine_readable == false)
|
|
||||||
{
|
|
||||||
char *hash_type = strhashtype (hashconfig->hash_mode); // not a bug
|
|
||||||
|
|
||||||
log_info ("Hashtype: %s", hash_type);
|
|
||||||
log_info ("");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* weak hash check is the first to write to potfile, so open it for writing from here
|
* weak hash check is the first to write to potfile, so open it for writing from here
|
||||||
@ -767,7 +666,7 @@ static int outer_loop (hashcat_ctx_t *hashcat_ctx)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (user_options->quiet == false) log_info_nn ("Checking for weak hashes...");
|
EVENT_SEND (EVENT_OUTERLOOP_WEAK_HASH);
|
||||||
|
|
||||||
for (u32 salt_pos = 0; salt_pos < hashes->salts_cnt; salt_pos++)
|
for (u32 salt_pos = 0; salt_pos < hashes->salts_cnt; salt_pos++)
|
||||||
{
|
{
|
||||||
@ -807,25 +706,12 @@ static int outer_loop (hashcat_ctx_t *hashcat_ctx)
|
|||||||
* Tell user about cracked hashes by potfile
|
* Tell user about cracked hashes by potfile
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (user_options->quiet == false)
|
EVENT_SEND (EVENT_POTFILE_NUM_CRACKED);
|
||||||
{
|
|
||||||
if (potfile_remove_cracks > 0)
|
|
||||||
{
|
|
||||||
if (potfile_remove_cracks == 1)
|
|
||||||
{
|
|
||||||
log_info ("INFO: Removed 1 hash found in potfile");
|
|
||||||
log_info ("");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
log_info ("INFO: Removed %d hashes found in potfile", potfile_remove_cracks);
|
|
||||||
log_info ("");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// main call
|
// main call
|
||||||
|
|
||||||
|
EVENT_SEND (EVENT_INNERLOOP1_STARTING);
|
||||||
|
|
||||||
if (mask_ctx->masks_cnt)
|
if (mask_ctx->masks_cnt)
|
||||||
{
|
{
|
||||||
restore_data_t *rd = restore_ctx->rd;
|
restore_data_t *rd = restore_ctx->rd;
|
||||||
@ -866,6 +752,8 @@ static int outer_loop (hashcat_ctx_t *hashcat_ctx)
|
|||||||
|
|
||||||
myfree (inner_threads);
|
myfree (inner_threads);
|
||||||
|
|
||||||
|
EVENT_SEND (EVENT_INNERLOOP1_FINISHED);
|
||||||
|
|
||||||
// finalize potfile
|
// finalize potfile
|
||||||
|
|
||||||
potfile_write_close (hashcat_ctx);
|
potfile_write_close (hashcat_ctx);
|
||||||
|
266
src/main.c
266
src/main.c
@ -10,18 +10,20 @@
|
|||||||
#include "common.h"
|
#include "common.h"
|
||||||
#include "types.h"
|
#include "types.h"
|
||||||
#include "user_options.h"
|
#include "user_options.h"
|
||||||
|
#include "usage.h"
|
||||||
#include "hashcat.h"
|
#include "hashcat.h"
|
||||||
#include "memory.h" // commandline only
|
|
||||||
#include "terminal.h" // commandline only
|
|
||||||
#include "usage.h" // commandline only
|
|
||||||
#include "logging.h" // commandline only
|
|
||||||
#include "logfile.h" // commandline only
|
|
||||||
#include "thread.h" // commandline only
|
|
||||||
#include "status.h" // commandline only
|
|
||||||
|
|
||||||
#define RUN_AS_COMMANDLINE true
|
#define RUN_AS_COMMANDLINE
|
||||||
|
|
||||||
#if (RUN_AS_COMMANDLINE == true)
|
#if defined (RUN_AS_COMMANDLINE)
|
||||||
|
|
||||||
|
#include "memory.h"
|
||||||
|
#include "terminal.h"
|
||||||
|
#include "logging.h"
|
||||||
|
#include "logfile.h"
|
||||||
|
#include "thread.h"
|
||||||
|
#include "status.h"
|
||||||
|
#include "interface.h"
|
||||||
|
|
||||||
static int event_welcome_screen (hashcat_ctx_t *hashcat_ctx)
|
static int event_welcome_screen (hashcat_ctx_t *hashcat_ctx)
|
||||||
{
|
{
|
||||||
@ -103,10 +105,11 @@ static int event_logfile_sub_finalize (hashcat_ctx_t *hashcat_ctx)
|
|||||||
|
|
||||||
static int event_outerloop_starting (hashcat_ctx_t *hashcat_ctx)
|
static int event_outerloop_starting (hashcat_ctx_t *hashcat_ctx)
|
||||||
{
|
{
|
||||||
|
const user_options_t *user_options = hashcat_ctx->user_options;
|
||||||
|
const user_options_extra_t *user_options_extra = hashcat_ctx->user_options_extra;
|
||||||
|
|
||||||
hashcat_user_t *hashcat_user = hashcat_ctx->hashcat_user;
|
hashcat_user_t *hashcat_user = hashcat_ctx->hashcat_user;
|
||||||
status_ctx_t *status_ctx = hashcat_ctx->status_ctx;
|
status_ctx_t *status_ctx = hashcat_ctx->status_ctx;
|
||||||
user_options_t *user_options = hashcat_ctx->user_options;
|
|
||||||
user_options_extra_t *user_options_extra = hashcat_ctx->user_options_extra;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* keypress thread
|
* keypress thread
|
||||||
@ -156,8 +159,10 @@ static int event_outerloop_finished (hashcat_ctx_t *hashcat_ctx)
|
|||||||
|
|
||||||
static int event_cracker_starting (hashcat_ctx_t *hashcat_ctx)
|
static int event_cracker_starting (hashcat_ctx_t *hashcat_ctx)
|
||||||
{
|
{
|
||||||
user_options_t *user_options = hashcat_ctx->user_options;
|
const user_options_t *user_options = hashcat_ctx->user_options;
|
||||||
user_options_extra_t *user_options_extra = hashcat_ctx->user_options_extra;
|
const user_options_extra_t *user_options_extra = hashcat_ctx->user_options_extra;
|
||||||
|
|
||||||
|
if (user_options->quiet == true) return 0;
|
||||||
|
|
||||||
// Tell the user we're about to start
|
// Tell the user we're about to start
|
||||||
|
|
||||||
@ -165,13 +170,13 @@ static int event_cracker_starting (hashcat_ctx_t *hashcat_ctx)
|
|||||||
{
|
{
|
||||||
if ((user_options->quiet == false) && (user_options->status == false) && (user_options->benchmark == false))
|
if ((user_options->quiet == false) && (user_options->status == false) && (user_options->benchmark == false))
|
||||||
{
|
{
|
||||||
if (user_options->quiet == false) send_prompt ();
|
send_prompt ();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (user_options_extra->wordlist_mode == WL_MODE_STDIN)
|
else if (user_options_extra->wordlist_mode == WL_MODE_STDIN)
|
||||||
{
|
{
|
||||||
if (user_options->quiet == false) log_info ("Starting attack in stdin mode...");
|
log_info ("Starting attack in stdin mode...");
|
||||||
if (user_options->quiet == false) log_info ("");
|
log_info ("");
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -179,8 +184,8 @@ static int event_cracker_starting (hashcat_ctx_t *hashcat_ctx)
|
|||||||
|
|
||||||
static int event_cracker_finished (hashcat_ctx_t *hashcat_ctx)
|
static int event_cracker_finished (hashcat_ctx_t *hashcat_ctx)
|
||||||
{
|
{
|
||||||
logfile_ctx_t *logfile_ctx = hashcat_ctx->logfile_ctx;
|
const logfile_ctx_t *logfile_ctx = hashcat_ctx->logfile_ctx;
|
||||||
status_ctx_t *status_ctx = hashcat_ctx->status_ctx;
|
const status_ctx_t *status_ctx = hashcat_ctx->status_ctx;
|
||||||
|
|
||||||
logfile_sub_var_uint ("status-after-work", status_ctx->devices_status);
|
logfile_sub_var_uint ("status-after-work", status_ctx->devices_status);
|
||||||
|
|
||||||
@ -189,8 +194,8 @@ static int event_cracker_finished (hashcat_ctx_t *hashcat_ctx)
|
|||||||
|
|
||||||
static int event_cracker_final_stats (hashcat_ctx_t *hashcat_ctx)
|
static int event_cracker_final_stats (hashcat_ctx_t *hashcat_ctx)
|
||||||
{
|
{
|
||||||
hashes_t *hashes = hashcat_ctx->hashes;
|
const hashes_t *hashes = hashcat_ctx->hashes;
|
||||||
user_options_t *user_options = hashcat_ctx->user_options;
|
const user_options_t *user_options = hashcat_ctx->user_options;
|
||||||
|
|
||||||
// print final status
|
// print final status
|
||||||
|
|
||||||
@ -231,8 +236,8 @@ static int event_cracker_final_stats (hashcat_ctx_t *hashcat_ctx)
|
|||||||
|
|
||||||
static int event_cracker_hash_cracked (hashcat_ctx_t *hashcat_ctx)
|
static int event_cracker_hash_cracked (hashcat_ctx_t *hashcat_ctx)
|
||||||
{
|
{
|
||||||
hashes_t *hashes = hashcat_ctx->hashes;
|
const hashes_t *hashes = hashcat_ctx->hashes;
|
||||||
user_options_t *user_options = hashcat_ctx->user_options;
|
const user_options_t *user_options = hashcat_ctx->user_options;
|
||||||
|
|
||||||
if (hashes == NULL) hashes = NULL;
|
if (hashes == NULL) hashes = NULL;
|
||||||
if (user_options == NULL) user_options = NULL;
|
if (user_options == NULL) user_options = NULL;
|
||||||
@ -240,6 +245,190 @@ static int event_cracker_hash_cracked (hashcat_ctx_t *hashcat_ctx)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int event_calculated_words_base (hashcat_ctx_t *hashcat_ctx)
|
||||||
|
{
|
||||||
|
const status_ctx_t *status_ctx = hashcat_ctx->status_ctx;
|
||||||
|
const user_options_t *user_options = hashcat_ctx->user_options;
|
||||||
|
|
||||||
|
if (user_options->keyspace == true)
|
||||||
|
{
|
||||||
|
log_info ("%" PRIu64 "", status_ctx->words_base);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int event_potfile_remove_parse (hashcat_ctx_t *hashcat_ctx)
|
||||||
|
{
|
||||||
|
const user_options_t *user_options = hashcat_ctx->user_options;
|
||||||
|
|
||||||
|
if (user_options->quiet == true) return 0;
|
||||||
|
|
||||||
|
log_info_nn ("Comparing hashes with potfile entries...");
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int event_potfile_num_cracked (hashcat_ctx_t *hashcat_ctx)
|
||||||
|
{
|
||||||
|
const user_options_t *user_options = hashcat_ctx->user_options;
|
||||||
|
const hashes_t *hashes = hashcat_ctx->hashes;
|
||||||
|
|
||||||
|
if (user_options->quiet == true) return 0;
|
||||||
|
|
||||||
|
const int potfile_remove_cracks = hashes->digests_done;
|
||||||
|
|
||||||
|
if (potfile_remove_cracks > 0)
|
||||||
|
{
|
||||||
|
if (potfile_remove_cracks == 1)
|
||||||
|
{
|
||||||
|
log_info ("INFO: Removed 1 hash found in potfile");
|
||||||
|
log_info ("");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
log_info ("INFO: Removed %d hashes found in potfile", potfile_remove_cracks);
|
||||||
|
log_info ("");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int event_potfile_all_cracked (hashcat_ctx_t *hashcat_ctx)
|
||||||
|
{
|
||||||
|
const user_options_t *user_options = hashcat_ctx->user_options;
|
||||||
|
|
||||||
|
if (user_options->quiet == true) return 0;
|
||||||
|
|
||||||
|
log_info ("INFO: All hashes found in potfile! You can use --show to display them.");
|
||||||
|
log_info ("");
|
||||||
|
log_info ("INFO: No more hashes left to crack, exiting...");
|
||||||
|
log_info ("");
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int event_outerloop_mainscreen (hashcat_ctx_t *hashcat_ctx)
|
||||||
|
{
|
||||||
|
const bitmap_ctx_t *bitmap_ctx = hashcat_ctx->bitmap_ctx;
|
||||||
|
const hashconfig_t *hashconfig = hashcat_ctx->hashconfig;
|
||||||
|
const hashes_t *hashes = hashcat_ctx->hashes;
|
||||||
|
const hwmon_ctx_t *hwmon_ctx = hashcat_ctx->hwmon_ctx;
|
||||||
|
const straight_ctx_t *straight_ctx = hashcat_ctx->straight_ctx;
|
||||||
|
const user_options_t *user_options = hashcat_ctx->user_options;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* In benchmark-mode, inform user which algorithm is checked
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (user_options->benchmark == true)
|
||||||
|
{
|
||||||
|
if (user_options->machine_readable == false)
|
||||||
|
{
|
||||||
|
char *hash_type = strhashtype (hashconfig->hash_mode); // not a bug
|
||||||
|
|
||||||
|
log_info ("Hashtype: %s", hash_type);
|
||||||
|
log_info ("");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (user_options->quiet == true) return 0;
|
||||||
|
|
||||||
|
log_info ("Hashes: %u digests; %u unique digests, %u unique salts", hashes->hashes_cnt_orig, hashes->digests_cnt, hashes->salts_cnt);
|
||||||
|
|
||||||
|
log_info ("Bitmaps: %u bits, %u entries, 0x%08x mask, %u bytes, %u/%u rotates", bitmap_ctx->bitmap_bits, bitmap_ctx->bitmap_nums, bitmap_ctx->bitmap_mask, bitmap_ctx->bitmap_size, bitmap_ctx->bitmap_shift1, bitmap_ctx->bitmap_shift2);
|
||||||
|
|
||||||
|
if (user_options->attack_mode == ATTACK_MODE_STRAIGHT)
|
||||||
|
{
|
||||||
|
log_info ("Rules: %u", straight_ctx->kernel_rules_cnt);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (user_options->quiet == false) log_info ("");
|
||||||
|
|
||||||
|
if (hashconfig->opti_type)
|
||||||
|
{
|
||||||
|
log_info ("Applicable Optimizers:");
|
||||||
|
|
||||||
|
for (u32 i = 0; i < 32; i++)
|
||||||
|
{
|
||||||
|
const u32 opti_bit = 1u << i;
|
||||||
|
|
||||||
|
if (hashconfig->opti_type & opti_bit) log_info ("* %s", stroptitype (opti_bit));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
log_info ("");
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Watchdog and Temperature balance
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (hwmon_ctx->enabled == false && user_options->gpu_temp_disable == false)
|
||||||
|
{
|
||||||
|
log_info ("Watchdog: Hardware Monitoring Interface not found on your system");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (hwmon_ctx->enabled == true && user_options->gpu_temp_abort > 0)
|
||||||
|
{
|
||||||
|
log_info ("Watchdog: Temperature abort trigger set to %uc", user_options->gpu_temp_abort);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
log_info ("Watchdog: Temperature abort trigger disabled");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (hwmon_ctx->enabled == true && user_options->gpu_temp_retain > 0)
|
||||||
|
{
|
||||||
|
log_info ("Watchdog: Temperature retain trigger set to %uc", user_options->gpu_temp_retain);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
log_info ("Watchdog: Temperature retain trigger disabled");
|
||||||
|
}
|
||||||
|
|
||||||
|
log_info ("");
|
||||||
|
|
||||||
|
#if defined (DEBUG)
|
||||||
|
if (user_options->benchmark == true) log_info ("Hashmode: %d", hashconfig->hash_mode);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int event_opencl_session_pre (hashcat_ctx_t *hashcat_ctx)
|
||||||
|
{
|
||||||
|
const user_options_t *user_options = hashcat_ctx->user_options;
|
||||||
|
|
||||||
|
if (user_options->quiet == true) return 0;
|
||||||
|
|
||||||
|
log_info_nn ("Initializing device kernels and memory...");
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int event_opencl_session_post (hashcat_ctx_t *hashcat_ctx)
|
||||||
|
{
|
||||||
|
const user_options_t *user_options = hashcat_ctx->user_options;
|
||||||
|
|
||||||
|
if (user_options->quiet == true) return 0;
|
||||||
|
|
||||||
|
log_info_nn ("");
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int event_outerloop_weak_hash (hashcat_ctx_t *hashcat_ctx)
|
||||||
|
{
|
||||||
|
const user_options_t *user_options = hashcat_ctx->user_options;
|
||||||
|
|
||||||
|
if (user_options->quiet == true) return 0;
|
||||||
|
|
||||||
|
log_info_nn ("Checking for weak hashes...");
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
int event (hashcat_ctx_t *hashcat_ctx, const u32 event)
|
int event (hashcat_ctx_t *hashcat_ctx, const u32 event)
|
||||||
{
|
{
|
||||||
int rc = 0;
|
int rc = 0;
|
||||||
@ -254,10 +443,18 @@ int event (hashcat_ctx_t *hashcat_ctx, const u32 event)
|
|||||||
case EVENT_LOGFILE_SUB_FINALIZE: rc = event_logfile_sub_finalize (hashcat_ctx); break;
|
case EVENT_LOGFILE_SUB_FINALIZE: rc = event_logfile_sub_finalize (hashcat_ctx); break;
|
||||||
case EVENT_OUTERLOOP_STARTING: rc = event_outerloop_starting (hashcat_ctx); break;
|
case EVENT_OUTERLOOP_STARTING: rc = event_outerloop_starting (hashcat_ctx); break;
|
||||||
case EVENT_OUTERLOOP_FINISHED: rc = event_outerloop_finished (hashcat_ctx); break;
|
case EVENT_OUTERLOOP_FINISHED: rc = event_outerloop_finished (hashcat_ctx); break;
|
||||||
|
case EVENT_OUTERLOOP_MAINSCREEN: rc = event_outerloop_mainscreen (hashcat_ctx); break;
|
||||||
|
case EVENT_OUTERLOOP_WEAK_HASH: rc = event_outerloop_weak_hash (hashcat_ctx); break;
|
||||||
case EVENT_CRACKER_STARTING: rc = event_cracker_starting (hashcat_ctx); break;
|
case EVENT_CRACKER_STARTING: rc = event_cracker_starting (hashcat_ctx); break;
|
||||||
case EVENT_CRACKER_FINISHED: rc = event_cracker_finished (hashcat_ctx); break;
|
case EVENT_CRACKER_FINISHED: rc = event_cracker_finished (hashcat_ctx); break;
|
||||||
case EVENT_CRACKER_FINAL_STATS: rc = event_cracker_final_stats (hashcat_ctx); break;
|
case EVENT_CRACKER_FINAL_STATS: rc = event_cracker_final_stats (hashcat_ctx); break;
|
||||||
case EVENT_CRACKER_HASH_CRACKED: rc = event_cracker_hash_cracked (hashcat_ctx); break;
|
case EVENT_CRACKER_HASH_CRACKED: rc = event_cracker_hash_cracked (hashcat_ctx); break;
|
||||||
|
case EVENT_CALCULATED_WORDS_BASE: rc = event_calculated_words_base (hashcat_ctx); break;
|
||||||
|
case EVENT_POTFILE_REMOVE_PARSE: rc = event_potfile_remove_parse (hashcat_ctx); break;
|
||||||
|
case EVENT_POTFILE_NUM_CRACKED: rc = event_potfile_num_cracked (hashcat_ctx); break;
|
||||||
|
case EVENT_POTFILE_ALL_CRACKED: rc = event_potfile_all_cracked (hashcat_ctx); break;
|
||||||
|
case EVENT_OPENCL_SESSION_PRE: rc = event_opencl_session_pre (hashcat_ctx); break;
|
||||||
|
case EVENT_OPENCL_SESSION_POST: rc = event_opencl_session_post (hashcat_ctx); break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
@ -267,9 +464,15 @@ int event (hashcat_ctx_t *hashcat_ctx, const u32 event)
|
|||||||
|
|
||||||
int event (hashcat_ctx_t *hashcat_ctx, const u32 event)
|
int event (hashcat_ctx_t *hashcat_ctx, const u32 event)
|
||||||
{
|
{
|
||||||
|
if (hashcat_ctx == NULL) hashcat_ctx = NULL;
|
||||||
|
|
||||||
|
int rc = 0;
|
||||||
|
|
||||||
switch (event)
|
switch (event)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
@ -285,12 +488,8 @@ int main (int argc, char **argv)
|
|||||||
// initialize the session via getops for commandline use or
|
// initialize the session via getops for commandline use or
|
||||||
// alternatively you can set the user_options directly
|
// alternatively you can set the user_options directly
|
||||||
|
|
||||||
int rc_hashcat = 0;
|
#if defined (RUN_AS_COMMANDLINE)
|
||||||
|
|
||||||
bool run_as_commandline = RUN_AS_COMMANDLINE;
|
|
||||||
|
|
||||||
if (run_as_commandline == true)
|
|
||||||
{
|
|
||||||
// install and shared folder need to be set to recognize "make install" use
|
// install and shared folder need to be set to recognize "make install" use
|
||||||
|
|
||||||
char *install_folder = NULL;
|
char *install_folder = NULL;
|
||||||
@ -338,10 +537,10 @@ int main (int argc, char **argv)
|
|||||||
|
|
||||||
// now run hashcat
|
// now run hashcat
|
||||||
|
|
||||||
rc_hashcat = hashcat (hashcat_ctx, install_folder, shared_folder, argc, argv, COMPTIME);
|
const int rc_hashcat = hashcat (hashcat_ctx, install_folder, shared_folder, argc, argv, COMPTIME);
|
||||||
}
|
|
||||||
else
|
#else
|
||||||
{
|
|
||||||
// this is a bit ugly, but it's the example you're looking for
|
// this is a bit ugly, but it's the example you're looking for
|
||||||
|
|
||||||
char *hash = "8743b52063cd84097a65d1633f5c74f5";
|
char *hash = "8743b52063cd84097a65d1633f5c74f5";
|
||||||
@ -367,8 +566,9 @@ int main (int argc, char **argv)
|
|||||||
|
|
||||||
// now run hashcat
|
// now run hashcat
|
||||||
|
|
||||||
rc_hashcat = hashcat (hashcat_ctx, NULL, NULL, 0, NULL, 0);
|
const int rc_hashcat = hashcat (hashcat_ctx, NULL, NULL, 0, NULL, 0);
|
||||||
}
|
|
||||||
|
#endif
|
||||||
|
|
||||||
// finished with hashcat, clean up
|
// finished with hashcat, clean up
|
||||||
|
|
||||||
|
@ -762,30 +762,25 @@ void potfile_left_request_lm (hashcat_ctx_t *hashcat_ctx, char *input_buf, int i
|
|||||||
if (weak_hash_found == 1) myfree (pot_right_ptr);
|
if (weak_hash_found == 1) myfree (pot_right_ptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
int potfile_remove_parse (hashcat_ctx_t *hashcat_ctx)
|
void potfile_remove_parse (hashcat_ctx_t *hashcat_ctx)
|
||||||
{
|
{
|
||||||
hashconfig_t *hashconfig = hashcat_ctx->hashconfig;
|
hashconfig_t *hashconfig = hashcat_ctx->hashconfig;
|
||||||
hashes_t *hashes = hashcat_ctx->hashes;
|
hashes_t *hashes = hashcat_ctx->hashes;
|
||||||
potfile_ctx_t *potfile_ctx = hashcat_ctx->potfile_ctx;
|
potfile_ctx_t *potfile_ctx = hashcat_ctx->potfile_ctx;
|
||||||
|
|
||||||
if (potfile_ctx->enabled == false) return 0;
|
if (potfile_ctx->enabled == false) return;
|
||||||
|
|
||||||
hash_t *hashes_buf = hashes->hashes_buf;
|
hash_t *hashes_buf = hashes->hashes_buf;
|
||||||
u32 hashes_cnt = hashes->hashes_cnt;
|
u32 hashes_cnt = hashes->hashes_cnt;
|
||||||
|
|
||||||
// no solution for these special hash types (for instane because they use hashfile in output etc)
|
// no solution for these special hash types (for instane because they use hashfile in output etc)
|
||||||
|
|
||||||
if (hashconfig->hash_mode == 5200)
|
if (hashconfig->hash_mode == 5200) return;
|
||||||
return 0;
|
if ((hashconfig->hash_mode >= 6200)
|
||||||
|
&& (hashconfig->hash_mode <= 6299)) return;
|
||||||
if ((hashconfig->hash_mode >= 6200) && (hashconfig->hash_mode <= 6299))
|
if (hashconfig->hash_mode == 9000) return;
|
||||||
return 0;
|
if ((hashconfig->hash_mode >= 13700)
|
||||||
|
&& (hashconfig->hash_mode <= 13799)) return;
|
||||||
if (hashconfig->hash_mode == 9000)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
if ((hashconfig->hash_mode >= 13700) && (hashconfig->hash_mode <= 13799))
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
hash_t hash_buf;
|
hash_t hash_buf;
|
||||||
|
|
||||||
@ -807,9 +802,7 @@ int potfile_remove_parse (hashcat_ctx_t *hashcat_ctx)
|
|||||||
|
|
||||||
const int rc = potfile_read_open (hashcat_ctx);
|
const int rc = potfile_read_open (hashcat_ctx);
|
||||||
|
|
||||||
if (rc == -1) return 0;
|
if (rc == -1) return;
|
||||||
|
|
||||||
int potfile_remove_cracks = 0;
|
|
||||||
|
|
||||||
char *line_buf = (char *) mymalloc (HCBUFSIZ_LARGE);
|
char *line_buf = (char *) mymalloc (HCBUFSIZ_LARGE);
|
||||||
|
|
||||||
@ -946,8 +939,6 @@ int potfile_remove_parse (hashcat_ctx_t *hashcat_ctx)
|
|||||||
|
|
||||||
if (found == NULL) continue;
|
if (found == NULL) continue;
|
||||||
|
|
||||||
if (!found->cracked) potfile_remove_cracks++;
|
|
||||||
|
|
||||||
found->cracked = 1;
|
found->cracked = 1;
|
||||||
|
|
||||||
if (found) break;
|
if (found) break;
|
||||||
@ -973,6 +964,4 @@ int potfile_remove_parse (hashcat_ctx_t *hashcat_ctx)
|
|||||||
}
|
}
|
||||||
|
|
||||||
myfree (hash_buf.digest);
|
myfree (hash_buf.digest);
|
||||||
|
|
||||||
return potfile_remove_cracks;
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user