mirror of
https://github.com/hashcat/hashcat.git
synced 2025-01-11 00:01:16 +00:00
Move all induction folder related host code into induct.c
This commit is contained in:
parent
b6f966970b
commit
919b5d5148
@ -10,8 +10,11 @@
|
||||
#include <sys/stat.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#define INDUCT_DIR "induct"
|
||||
static const char INDUCT_DIR[] = "induct";
|
||||
|
||||
int sort_by_mtime (const void *p1, const void *p2);
|
||||
int induct_ctx_init (induct_ctx_t *induct_ctx, const user_options_t *user_options, const folder_config_t *folder_config, const time_t proc_start);
|
||||
void induct_ctx_scan (induct_ctx_t *induct_ctx);
|
||||
void induct_ctx_cleanup (induct_ctx_t *induct_ctx);
|
||||
void induct_ctx_destroy (induct_ctx_t *induct_ctx);
|
||||
|
||||
#endif // _INDUCT_H
|
||||
|
@ -892,6 +892,17 @@ typedef struct
|
||||
|
||||
} folder_config_t;
|
||||
|
||||
typedef struct
|
||||
{
|
||||
bool enabled;
|
||||
|
||||
char *root_directory;
|
||||
|
||||
char **induction_dictionaries;
|
||||
int induction_dictionaries_cnt;
|
||||
|
||||
} induct_ctx_t;
|
||||
|
||||
typedef struct
|
||||
{
|
||||
/**
|
||||
@ -965,7 +976,6 @@ typedef struct
|
||||
u32 maskpos;
|
||||
char *eff_restore_file;
|
||||
char *new_restore_file;
|
||||
char *induction_directory;
|
||||
char *outfile_check_directory;
|
||||
u32 pw_min;
|
||||
u32 pw_max;
|
||||
@ -981,6 +991,7 @@ typedef struct
|
||||
debugfile_ctx_t *debugfile_ctx;
|
||||
session_ctx_t *session_ctx;
|
||||
bitmap_ctx_t *bitmap_ctx;
|
||||
induct_ctx_t *induct_ctx;
|
||||
|
||||
/**
|
||||
* used for restore
|
||||
|
148
src/hashcat.c
148
src/hashcat.c
@ -331,65 +331,13 @@ int main (int argc, char **argv)
|
||||
* induction directory
|
||||
*/
|
||||
|
||||
char *induction_directory = NULL;
|
||||
induct_ctx_t *induct_ctx = (induct_ctx_t *) mymalloc (sizeof (induct_ctx_t));
|
||||
|
||||
if (user_options->attack_mode != ATTACK_MODE_BF)
|
||||
{
|
||||
if ((user_options->keyspace == false) && (user_options->benchmark == false) && (user_options->opencl_info == false))
|
||||
{
|
||||
if (user_options->induction_dir == NULL)
|
||||
{
|
||||
induction_directory = (char *) mymalloc (HCBUFSIZ_TINY);
|
||||
data.induct_ctx = induct_ctx;
|
||||
|
||||
snprintf (induction_directory, HCBUFSIZ_TINY - 1, "%s/%s.%s", folder_config->session_dir, user_options->session, INDUCT_DIR);
|
||||
const int rc_induct_ctx_init = induct_ctx_init (induct_ctx, user_options, folder_config, proc_start);
|
||||
|
||||
// create induction folder if it does not already exist
|
||||
|
||||
if (user_options->keyspace == false)
|
||||
{
|
||||
if (rmdir (induction_directory) == -1)
|
||||
{
|
||||
if (errno == ENOENT)
|
||||
{
|
||||
// good, we can ignore
|
||||
}
|
||||
else if (errno == ENOTEMPTY)
|
||||
{
|
||||
char *induction_directory_mv = (char *) mymalloc (HCBUFSIZ_TINY);
|
||||
|
||||
snprintf (induction_directory_mv, HCBUFSIZ_TINY - 1, "%s/%s.induct.%d", folder_config->session_dir, user_options->session, (int) proc_start);
|
||||
|
||||
if (rename (induction_directory, induction_directory_mv) != 0)
|
||||
{
|
||||
log_error ("ERROR: Rename directory %s to %s: %s", induction_directory, induction_directory_mv, strerror (errno));
|
||||
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
log_error ("ERROR: %s: %s", induction_directory, strerror (errno));
|
||||
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
|
||||
if (mkdir (induction_directory, 0700) == -1)
|
||||
{
|
||||
log_error ("ERROR: %s: %s", induction_directory, strerror (errno));
|
||||
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
induction_directory = user_options->induction_dir;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
data.induction_directory = induction_directory;
|
||||
if (rc_induct_ctx_init == -1) return -1;
|
||||
|
||||
/**
|
||||
* tuning db
|
||||
@ -2581,10 +2529,6 @@ int main (int argc, char **argv)
|
||||
}
|
||||
}
|
||||
|
||||
char **induction_dictionaries = NULL;
|
||||
|
||||
int induction_dictionaries_cnt = 0;
|
||||
|
||||
hcstat_table_t *root_table_buf = NULL;
|
||||
hcstat_table_t *markov_table_buf = NULL;
|
||||
|
||||
@ -2849,24 +2793,11 @@ int main (int argc, char **argv)
|
||||
}
|
||||
}
|
||||
|
||||
free (induction_dictionaries);
|
||||
/**
|
||||
* update induction directory scan
|
||||
*/
|
||||
|
||||
// induction_dictionaries_cnt = 0; // implied
|
||||
|
||||
if (user_options->attack_mode != ATTACK_MODE_BF)
|
||||
{
|
||||
if ((user_options->keyspace == false) && (user_options->benchmark == false) && (user_options->opencl_info == false))
|
||||
{
|
||||
induction_dictionaries = scan_directory (induction_directory);
|
||||
|
||||
induction_dictionaries_cnt = count_dictionaries (induction_dictionaries);
|
||||
}
|
||||
}
|
||||
|
||||
if (induction_dictionaries_cnt)
|
||||
{
|
||||
qsort (induction_dictionaries, induction_dictionaries_cnt, sizeof (char *), sort_by_mtime);
|
||||
}
|
||||
induct_ctx_scan (induct_ctx);
|
||||
|
||||
/**
|
||||
* prevent the user from using --skip/--limit together w/ maskfile and or dictfile
|
||||
@ -2977,9 +2908,9 @@ int main (int argc, char **argv)
|
||||
{
|
||||
char *dictfile = NULL;
|
||||
|
||||
if (induction_dictionaries_cnt)
|
||||
if (induct_ctx->induction_dictionaries_cnt)
|
||||
{
|
||||
dictfile = induction_dictionaries[0];
|
||||
dictfile = induct_ctx->induction_dictionaries[0];
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -3066,9 +2997,9 @@ int main (int argc, char **argv)
|
||||
{
|
||||
char *dictfile = NULL;
|
||||
|
||||
if (induction_dictionaries_cnt)
|
||||
if (induct_ctx->induction_dictionaries_cnt)
|
||||
{
|
||||
dictfile = induction_dictionaries[0];
|
||||
dictfile = induct_ctx->induction_dictionaries[0];
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -3426,7 +3357,7 @@ int main (int argc, char **argv)
|
||||
|
||||
if (user_options->loopback == true)
|
||||
{
|
||||
loopback_write_open (loopback_ctx, induction_directory);
|
||||
loopback_write_open (loopback_ctx, induct_ctx->root_directory);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -3584,22 +3515,14 @@ int main (int argc, char **argv)
|
||||
|
||||
user_options->restore = false;
|
||||
|
||||
if (induction_dictionaries_cnt)
|
||||
if (induct_ctx->induction_dictionaries_cnt)
|
||||
{
|
||||
unlink (induction_dictionaries[0]);
|
||||
unlink (induct_ctx->induction_dictionaries[0]);
|
||||
}
|
||||
|
||||
free (induction_dictionaries);
|
||||
myfree (induct_ctx->induction_dictionaries);
|
||||
|
||||
if (user_options->attack_mode != ATTACK_MODE_BF)
|
||||
{
|
||||
if ((user_options->keyspace == false) && (user_options->benchmark == false) && (user_options->opencl_info == false))
|
||||
{
|
||||
induction_dictionaries = scan_directory (induction_directory);
|
||||
|
||||
induction_dictionaries_cnt = count_dictionaries (induction_dictionaries);
|
||||
}
|
||||
}
|
||||
induct_ctx_scan (induct_ctx);
|
||||
|
||||
if (user_options->benchmark == true)
|
||||
{
|
||||
@ -3631,10 +3554,8 @@ int main (int argc, char **argv)
|
||||
}
|
||||
}
|
||||
|
||||
if (induction_dictionaries_cnt)
|
||||
if (induct_ctx->induction_dictionaries_cnt)
|
||||
{
|
||||
qsort (induction_dictionaries, induction_dictionaries_cnt, sizeof (char *), sort_by_mtime);
|
||||
|
||||
// yeah, this next statement is a little hack to make sure that --loopback runs correctly (because with it we guarantee that the loop iterates one more time)
|
||||
|
||||
dictpos--;
|
||||
@ -3713,15 +3634,7 @@ int main (int argc, char **argv)
|
||||
|
||||
// if cracked / aborted remove last induction dictionary
|
||||
|
||||
for (int file_pos = 0; file_pos < induction_dictionaries_cnt; file_pos++)
|
||||
{
|
||||
struct stat induct_stat;
|
||||
|
||||
if (stat (induction_dictionaries[file_pos], &induct_stat) == 0)
|
||||
{
|
||||
unlink (induction_dictionaries[file_pos]);
|
||||
}
|
||||
}
|
||||
induct_ctx_cleanup (induct_ctx);
|
||||
|
||||
// wait for inner threads
|
||||
|
||||
@ -3990,28 +3903,7 @@ int main (int argc, char **argv)
|
||||
|
||||
// induction directory
|
||||
|
||||
if (induction_directory != NULL)
|
||||
{
|
||||
if (rmdir (induction_directory) == -1)
|
||||
{
|
||||
if (errno == ENOENT)
|
||||
{
|
||||
// good, we can ignore
|
||||
}
|
||||
else if (errno == ENOTEMPTY)
|
||||
{
|
||||
// good, we can ignore
|
||||
}
|
||||
else
|
||||
{
|
||||
log_error ("ERROR: %s: %s", induction_directory, strerror (errno));
|
||||
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
|
||||
local_free (induction_directory);
|
||||
}
|
||||
induct_ctx_destroy (induct_ctx);
|
||||
|
||||
// outfile-check directory
|
||||
|
||||
|
126
src/induct.c
126
src/induct.c
@ -4,9 +4,13 @@
|
||||
*/
|
||||
|
||||
#include "common.h"
|
||||
#include "types.h"
|
||||
#include "memory.h"
|
||||
#include "logging.h"
|
||||
#include "folder.h"
|
||||
#include "induct.h"
|
||||
|
||||
int sort_by_mtime (const void *p1, const void *p2)
|
||||
static int sort_by_mtime (const void *p1, const void *p2)
|
||||
{
|
||||
const char **f1 = (const char **) p1;
|
||||
const char **f2 = (const char **) p2;
|
||||
@ -16,3 +20,123 @@ int sort_by_mtime (const void *p1, const void *p2)
|
||||
|
||||
return s2.st_mtime - s1.st_mtime;
|
||||
}
|
||||
|
||||
int induct_ctx_init (induct_ctx_t *induct_ctx, const user_options_t *user_options, const folder_config_t *folder_config, const time_t proc_start)
|
||||
{
|
||||
induct_ctx->enabled = false;
|
||||
|
||||
if (user_options->attack_mode == ATTACK_MODE_BF) return 0;
|
||||
|
||||
if (user_options->keyspace == true) return 0;
|
||||
if (user_options->benchmark == true) return 0;
|
||||
if (user_options->opencl_info == true) return 0;
|
||||
|
||||
if (user_options->induction_dir == NULL)
|
||||
{
|
||||
char *root_directory = (char *) mymalloc (HCBUFSIZ_TINY);
|
||||
|
||||
snprintf (root_directory, HCBUFSIZ_TINY - 1, "%s/%s.%s", folder_config->session_dir, user_options->session, INDUCT_DIR);
|
||||
|
||||
if (rmdir (root_directory) == -1)
|
||||
{
|
||||
if (errno == ENOENT)
|
||||
{
|
||||
// good, we can ignore
|
||||
}
|
||||
else if (errno == ENOTEMPTY)
|
||||
{
|
||||
char *root_directory_mv = (char *) mymalloc (HCBUFSIZ_TINY);
|
||||
|
||||
snprintf (root_directory_mv, HCBUFSIZ_TINY - 1, "%s/%s.induct.%d", folder_config->session_dir, user_options->session, (int) proc_start);
|
||||
|
||||
if (rename (root_directory, root_directory_mv) != 0)
|
||||
{
|
||||
log_error ("ERROR: Rename directory %s to %s: %s", root_directory, root_directory_mv, strerror (errno));
|
||||
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
log_error ("ERROR: %s: %s", root_directory, strerror (errno));
|
||||
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
|
||||
if (mkdir (root_directory, 0700) == -1)
|
||||
{
|
||||
log_error ("ERROR: %s: %s", root_directory, strerror (errno));
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
induct_ctx->root_directory = root_directory;
|
||||
}
|
||||
else
|
||||
{
|
||||
induct_ctx->root_directory = mystrdup (user_options->induction_dir);
|
||||
}
|
||||
|
||||
induct_ctx->enabled = true;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
void induct_ctx_scan (induct_ctx_t *induct_ctx)
|
||||
{
|
||||
if (induct_ctx->enabled == false) return;
|
||||
|
||||
induct_ctx->induction_dictionaries = scan_directory (induct_ctx->root_directory);
|
||||
|
||||
induct_ctx->induction_dictionaries_cnt = count_dictionaries (induct_ctx->induction_dictionaries);
|
||||
|
||||
qsort (induct_ctx->induction_dictionaries, induct_ctx->induction_dictionaries_cnt, sizeof (char *), sort_by_mtime);
|
||||
}
|
||||
|
||||
void induct_ctx_cleanup (induct_ctx_t *induct_ctx)
|
||||
{
|
||||
if (induct_ctx->enabled == false) return;
|
||||
|
||||
for (int file_pos = 0; file_pos < induct_ctx->induction_dictionaries_cnt; file_pos++)
|
||||
{
|
||||
struct stat induct_stat;
|
||||
|
||||
if (stat (induct_ctx->induction_dictionaries[file_pos], &induct_stat) == 0)
|
||||
{
|
||||
unlink (induct_ctx->induction_dictionaries[file_pos]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void induct_ctx_destroy (induct_ctx_t *induct_ctx)
|
||||
{
|
||||
if (induct_ctx->enabled == false)
|
||||
{
|
||||
myfree (induct_ctx);
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
if (rmdir (induct_ctx->root_directory) == -1)
|
||||
{
|
||||
if (errno == ENOENT)
|
||||
{
|
||||
// good, we can ignore
|
||||
}
|
||||
else if (errno == ENOTEMPTY)
|
||||
{
|
||||
// good, we can ignore
|
||||
}
|
||||
else
|
||||
{
|
||||
log_error ("ERROR: %s: %s", induct_ctx->root_directory, strerror (errno));
|
||||
|
||||
//return -1;
|
||||
}
|
||||
}
|
||||
|
||||
myfree (induct_ctx->root_directory);
|
||||
|
||||
myfree (induct_ctx);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user