mirror of
https://github.com/hashcat/hashcat.git
synced 2024-11-30 03:48:17 +00:00
381 lines
8.7 KiB
C
381 lines
8.7 KiB
C
/**
|
|
* Author......: See docs/credits.txt
|
|
* License.....: MIT
|
|
*/
|
|
|
|
#include "common.h"
|
|
#include "types.h"
|
|
#include "memory.h"
|
|
#include "filehandling.h"
|
|
#include "hlfmt.h"
|
|
#include "shared.h"
|
|
|
|
static const char *HLFMT_TEXT_HASHCAT = "native hashcat";
|
|
static const char *HLFMT_TEXT_PWDUMP = "pwdump";
|
|
static const char *HLFMT_TEXT_PASSWD = "passwd";
|
|
static const char *HLFMT_TEXT_SHADOW = "shadow";
|
|
static const char *HLFMT_TEXT_DCC = "DCC";
|
|
static const char *HLFMT_TEXT_DCC2 = "DCC 2";
|
|
static const char *HLFMT_TEXT_NETNTLM1 = "NetNTLMv1";
|
|
static const char *HLFMT_TEXT_NETNTLM2 = "NetNTLMv2";
|
|
static const char *HLFMT_TEXT_NSLDAP = "nsldap";
|
|
static const char *HLFMT_TEXT_NSLDAPS = "nsldaps";
|
|
|
|
// hlfmt hashcat
|
|
|
|
static void hlfmt_hash_hashcat (MAYBE_UNUSED hashcat_ctx_t *hashcat_ctx, char *line_buf, const int line_len, char **hashbuf_pos, int *hashbuf_len)
|
|
{
|
|
const user_options_t *user_options = hashcat_ctx->user_options;
|
|
const hashconfig_t *hashconfig = hashcat_ctx->hashconfig;
|
|
|
|
if (user_options->username == 0)
|
|
{
|
|
*hashbuf_pos = line_buf;
|
|
*hashbuf_len = line_len;
|
|
}
|
|
else
|
|
{
|
|
char *pos = line_buf;
|
|
size_t len = line_len;
|
|
|
|
for (int i = 0; i < line_len; i++, pos++, len--)
|
|
{
|
|
if (line_buf[i] == hashconfig->separator)
|
|
{
|
|
pos++;
|
|
|
|
len--;
|
|
|
|
break;
|
|
}
|
|
}
|
|
|
|
*hashbuf_pos = pos;
|
|
*hashbuf_len = len;
|
|
}
|
|
}
|
|
|
|
static void hlfmt_user_hashcat (MAYBE_UNUSED hashcat_ctx_t *hashcat_ctx, char *line_buf, const int line_len, char **userbuf_pos, int *userbuf_len)
|
|
{
|
|
const hashconfig_t *hashconfig = hashcat_ctx->hashconfig;
|
|
|
|
char *pos = NULL;
|
|
size_t len = 0;
|
|
|
|
int sep_cnt = 0;
|
|
|
|
for (int i = 0; i < line_len; i++)
|
|
{
|
|
if (line_buf[i] == hashconfig->separator)
|
|
{
|
|
sep_cnt++;
|
|
|
|
continue;
|
|
}
|
|
|
|
if (sep_cnt == 0)
|
|
{
|
|
if (pos == NULL) pos = line_buf + i;
|
|
|
|
len++;
|
|
}
|
|
}
|
|
|
|
*userbuf_pos = pos;
|
|
*userbuf_len = len;
|
|
}
|
|
|
|
// hlfmt pwdump
|
|
|
|
static int hlfmt_detect_pwdump (MAYBE_UNUSED hashcat_ctx_t *hashcat_ctx, const char *line_buf, const int line_len)
|
|
{
|
|
int sep_cnt = 0;
|
|
|
|
int sep2_len = 0;
|
|
int sep3_len = 0;
|
|
|
|
for (int i = 0; i < line_len; i++)
|
|
{
|
|
if (line_buf[i] == ':')
|
|
{
|
|
sep_cnt++;
|
|
|
|
continue;
|
|
}
|
|
|
|
if (sep_cnt == 2) sep2_len++;
|
|
if (sep_cnt == 3) sep3_len++;
|
|
}
|
|
|
|
if ((sep_cnt == 6) && ((sep2_len == 32) || (sep3_len == 32))) return 1;
|
|
|
|
return 0;
|
|
}
|
|
|
|
static void hlfmt_hash_pwdump (MAYBE_UNUSED hashcat_ctx_t *hashcat_ctx, char *line_buf, const int line_len, char **hashbuf_pos, int *hashbuf_len)
|
|
{
|
|
const hashconfig_t *hashconfig = hashcat_ctx->hashconfig;
|
|
|
|
char *pos = NULL;
|
|
size_t len = 0;
|
|
|
|
int sep_cnt = 0;
|
|
|
|
for (int i = 0; i < line_len; i++)
|
|
{
|
|
if (line_buf[i] == ':')
|
|
{
|
|
sep_cnt++;
|
|
|
|
continue;
|
|
}
|
|
|
|
if (hashconfig->pwdump_column == PWDUMP_COLUMN_LM_HASH)
|
|
{
|
|
if (sep_cnt == 2)
|
|
{
|
|
if (pos == NULL) pos = line_buf + i;
|
|
|
|
len++;
|
|
}
|
|
}
|
|
else if (hashconfig->pwdump_column == PWDUMP_COLUMN_NTLM_HASH)
|
|
{
|
|
if (sep_cnt == 3)
|
|
{
|
|
if (pos == NULL) pos = line_buf + i;
|
|
|
|
len++;
|
|
}
|
|
}
|
|
}
|
|
|
|
*hashbuf_pos = pos;
|
|
*hashbuf_len = len;
|
|
}
|
|
|
|
static void hlfmt_user_pwdump (MAYBE_UNUSED hashcat_ctx_t *hashcat_ctx, char *line_buf, const int line_len, char **userbuf_pos, int *userbuf_len)
|
|
{
|
|
char *pos = NULL;
|
|
size_t len = 0;
|
|
|
|
int sep_cnt = 0;
|
|
|
|
for (int i = 0; i < line_len; i++)
|
|
{
|
|
if (line_buf[i] == ':')
|
|
{
|
|
sep_cnt++;
|
|
|
|
continue;
|
|
}
|
|
|
|
if (sep_cnt == 0)
|
|
{
|
|
if (pos == NULL) pos = line_buf + i;
|
|
|
|
len++;
|
|
}
|
|
}
|
|
|
|
*userbuf_pos = pos;
|
|
*userbuf_len = len;
|
|
}
|
|
|
|
// hlfmt passwd
|
|
|
|
static int hlfmt_detect_passwd (MAYBE_UNUSED hashcat_ctx_t *hashcat_ctx, const char *line_buf, const int line_len)
|
|
{
|
|
int sep_cnt = 0;
|
|
|
|
char sep5_first = 0;
|
|
char sep6_first = 0;
|
|
|
|
for (int i = 0; i < line_len; i++)
|
|
{
|
|
if (line_buf[i] == ':')
|
|
{
|
|
sep_cnt++;
|
|
|
|
continue;
|
|
}
|
|
|
|
if (sep_cnt == 5) if (sep5_first == 0) sep5_first = line_buf[i];
|
|
if (sep_cnt == 6) if (sep6_first == 0) sep6_first = line_buf[i];
|
|
}
|
|
|
|
if ((sep_cnt == 6) && ((sep5_first == '/') || (sep6_first == '/'))) return 1;
|
|
|
|
return 0;
|
|
}
|
|
|
|
static void hlfmt_hash_passwd (MAYBE_UNUSED hashcat_ctx_t *hashcat_ctx, char *line_buf, const int line_len, char **hashbuf_pos, int *hashbuf_len)
|
|
{
|
|
char *pos = NULL;
|
|
size_t len = 0;
|
|
|
|
int sep_cnt = 0;
|
|
|
|
for (int i = 0; i < line_len; i++)
|
|
{
|
|
if (line_buf[i] == ':')
|
|
{
|
|
sep_cnt++;
|
|
|
|
continue;
|
|
}
|
|
|
|
if (sep_cnt == 1)
|
|
{
|
|
if (pos == NULL) pos = line_buf + i;
|
|
|
|
len++;
|
|
}
|
|
}
|
|
|
|
*hashbuf_pos = pos;
|
|
*hashbuf_len = len;
|
|
}
|
|
|
|
static void hlfmt_user_passwd (MAYBE_UNUSED hashcat_ctx_t *hashcat_ctx, char *line_buf, const int line_len, char **userbuf_pos, int *userbuf_len)
|
|
{
|
|
char *pos = NULL;
|
|
size_t len = 0;
|
|
|
|
int sep_cnt = 0;
|
|
|
|
for (int i = 0; i < line_len; i++)
|
|
{
|
|
if (line_buf[i] == ':')
|
|
{
|
|
sep_cnt++;
|
|
|
|
continue;
|
|
}
|
|
|
|
if (sep_cnt == 0)
|
|
{
|
|
if (pos == NULL) pos = line_buf + i;
|
|
|
|
len++;
|
|
}
|
|
}
|
|
|
|
*userbuf_pos = pos;
|
|
*userbuf_len = len;
|
|
}
|
|
|
|
// hlfmt shadow
|
|
|
|
static int hlfmt_detect_shadow (MAYBE_UNUSED hashcat_ctx_t *hashcat_ctx, const char *line_buf, const int line_len)
|
|
{
|
|
int sep_cnt = 0;
|
|
|
|
for (int i = 0; i < line_len; i++)
|
|
{
|
|
if (line_buf[i] == ':') sep_cnt++;
|
|
}
|
|
|
|
if (sep_cnt == 8) return 1;
|
|
|
|
return 0;
|
|
}
|
|
|
|
static void hlfmt_hash_shadow (MAYBE_UNUSED hashcat_ctx_t *hashcat_ctx, char *line_buf, const int line_len, char **hashbuf_pos, int *hashbuf_len)
|
|
{
|
|
hlfmt_hash_passwd (hashcat_ctx, line_buf, line_len, hashbuf_pos, hashbuf_len);
|
|
}
|
|
|
|
static void hlfmt_user_shadow (MAYBE_UNUSED hashcat_ctx_t *hashcat_ctx, char *line_buf, const int line_len, char **userbuf_pos, int *userbuf_len)
|
|
{
|
|
hlfmt_user_passwd (hashcat_ctx, line_buf, line_len, userbuf_pos, userbuf_len);
|
|
}
|
|
|
|
// hlfmt main
|
|
|
|
const char *strhlfmt (const u32 hashfile_format)
|
|
{
|
|
switch (hashfile_format)
|
|
{
|
|
case HLFMT_HASHCAT: return HLFMT_TEXT_HASHCAT;
|
|
case HLFMT_PWDUMP: return HLFMT_TEXT_PWDUMP;
|
|
case HLFMT_PASSWD: return HLFMT_TEXT_PASSWD;
|
|
case HLFMT_SHADOW: return HLFMT_TEXT_SHADOW;
|
|
case HLFMT_DCC: return HLFMT_TEXT_DCC;
|
|
case HLFMT_DCC2: return HLFMT_TEXT_DCC2;
|
|
case HLFMT_NETNTLM1: return HLFMT_TEXT_NETNTLM1;
|
|
case HLFMT_NETNTLM2: return HLFMT_TEXT_NETNTLM2;
|
|
case HLFMT_NSLDAP: return HLFMT_TEXT_NSLDAP;
|
|
case HLFMT_NSLDAPS: return HLFMT_TEXT_NSLDAPS;
|
|
}
|
|
|
|
return "Unknown";
|
|
}
|
|
|
|
void hlfmt_hash (hashcat_ctx_t *hashcat_ctx, u32 hashfile_format, char *line_buf, const int line_len, char **hashbuf_pos, int *hashbuf_len)
|
|
{
|
|
switch (hashfile_format)
|
|
{
|
|
case HLFMT_HASHCAT: hlfmt_hash_hashcat (hashcat_ctx, line_buf, line_len, hashbuf_pos, hashbuf_len); break;
|
|
case HLFMT_PWDUMP: hlfmt_hash_pwdump (hashcat_ctx, line_buf, line_len, hashbuf_pos, hashbuf_len); break;
|
|
case HLFMT_PASSWD: hlfmt_hash_passwd (hashcat_ctx, line_buf, line_len, hashbuf_pos, hashbuf_len); break;
|
|
case HLFMT_SHADOW: hlfmt_hash_shadow (hashcat_ctx, line_buf, line_len, hashbuf_pos, hashbuf_len); break;
|
|
}
|
|
}
|
|
|
|
void hlfmt_user (hashcat_ctx_t *hashcat_ctx, u32 hashfile_format, char *line_buf, const int line_len, char **userbuf_pos, int *userbuf_len)
|
|
{
|
|
switch (hashfile_format)
|
|
{
|
|
case HLFMT_HASHCAT: hlfmt_user_hashcat (hashcat_ctx, line_buf, line_len, userbuf_pos, userbuf_len); break;
|
|
case HLFMT_PWDUMP: hlfmt_user_pwdump (hashcat_ctx, line_buf, line_len, userbuf_pos, userbuf_len); break;
|
|
case HLFMT_PASSWD: hlfmt_user_passwd (hashcat_ctx, line_buf, line_len, userbuf_pos, userbuf_len); break;
|
|
case HLFMT_SHADOW: hlfmt_user_shadow (hashcat_ctx, line_buf, line_len, userbuf_pos, userbuf_len); break;
|
|
}
|
|
}
|
|
|
|
u32 hlfmt_detect (hashcat_ctx_t *hashcat_ctx, HCFILE *fp, u32 max_check)
|
|
{
|
|
const hashconfig_t *hashconfig = hashcat_ctx->hashconfig;
|
|
|
|
// Exception: those formats are wrongly detected as HLFMT_SHADOW, prevent it
|
|
|
|
if (hashconfig->hlfmt_disable == true) return HLFMT_HASHCAT;
|
|
|
|
u32 *formats_cnt = (u32 *) hccalloc (HLFMTS_CNT, sizeof (u32));
|
|
|
|
u32 num_check = 0;
|
|
|
|
char *line_buf = (char *) hcmalloc (HCBUFSIZ_LARGE);
|
|
|
|
while (!hc_feof (fp))
|
|
{
|
|
const size_t line_len = fgetl (fp, line_buf, HCBUFSIZ_LARGE);
|
|
|
|
if (line_len == 0) continue;
|
|
|
|
if (hlfmt_detect_pwdump (hashcat_ctx, line_buf, line_len)) formats_cnt[HLFMT_PWDUMP]++;
|
|
if (hlfmt_detect_passwd (hashcat_ctx, line_buf, line_len)) formats_cnt[HLFMT_PASSWD]++;
|
|
if (hlfmt_detect_shadow (hashcat_ctx, line_buf, line_len)) formats_cnt[HLFMT_SHADOW]++;
|
|
|
|
if (num_check == max_check) break;
|
|
|
|
num_check++;
|
|
}
|
|
|
|
hcfree (line_buf);
|
|
|
|
u32 hashlist_format = HLFMT_HASHCAT;
|
|
|
|
for (u32 i = 1; i < HLFMTS_CNT; i++)
|
|
{
|
|
if (formats_cnt[i - 1] >= formats_cnt[i]) continue;
|
|
|
|
hashlist_format = i;
|
|
}
|
|
|
|
free (formats_cnt);
|
|
|
|
return hashlist_format;
|
|
}
|