1
0
mirror of https://github.com/hashcat/hashcat.git synced 2025-01-10 15:51:10 +00:00

Make sure to unlink the pidfile only if our instance created it, but even in case of error

This commit is contained in:
jsteube 2017-02-17 08:59:22 +01:00
parent ef004e85f0
commit 79e8b6a6b9
4 changed files with 12 additions and 14 deletions

View File

@ -20,8 +20,6 @@
#include <psapi.h>
#endif // _WIN
void unlink_pidfile (hashcat_ctx_t *hashcat_ctx);
int pidfile_ctx_init (hashcat_ctx_t *hashcat_ctx);
void pidfile_ctx_destroy (hashcat_ctx_t *hashcat_ctx);

View File

@ -1319,6 +1319,8 @@ typedef struct pidfile_ctx
pidfile_data_t *pd;
bool pidfile_written;
} pidfile_ctx_t;
typedef struct kernel_rule

View File

@ -1125,10 +1125,6 @@ int hashcat_session_execute (hashcat_ctx_t *hashcat_ctx)
unlink_restore (hashcat_ctx);
// unlink the pidfile
unlink_pidfile (hashcat_ctx);
// final update dictionary cache
dictstat_write (hashcat_ctx);

View File

@ -143,13 +143,6 @@ static int write_pidfile (hashcat_ctx_t *hashcat_ctx)
return 0;
}
void unlink_pidfile (hashcat_ctx_t *hashcat_ctx)
{
pidfile_ctx_t *pidfile_ctx = hashcat_ctx->pidfile_ctx;
unlink (pidfile_ctx->filename);
}
int pidfile_ctx_init (hashcat_ctx_t *hashcat_ctx)
{
folder_config_t *folder_config = hashcat_ctx->folder_config;
@ -158,11 +151,15 @@ int pidfile_ctx_init (hashcat_ctx_t *hashcat_ctx)
hc_asprintf (&pidfile_ctx->filename, "%s/%s.pid", folder_config->session_dir, user_options->session);
pidfile_ctx->pidfile_written = false;
const int rc_init_pidfile = init_pidfile (hashcat_ctx);
if (rc_init_pidfile == -1) return -1;
write_pidfile (hashcat_ctx);
const int rc = write_pidfile (hashcat_ctx);
if (rc == 0) pidfile_ctx->pidfile_written = true;
return 0;
}
@ -171,6 +168,11 @@ void pidfile_ctx_destroy (hashcat_ctx_t *hashcat_ctx)
{
pidfile_ctx_t *pidfile_ctx = hashcat_ctx->pidfile_ctx;
if (pidfile_ctx->pidfile_written == true)
{
unlink (pidfile_ctx->filename);
}
hcfree (pidfile_ctx->filename);
hcfree (pidfile_ctx->pd);