From f4dfbeaec4bfb5369f1f4bf16c06178107384177 Mon Sep 17 00:00:00 2001 From: Benjamin Franzke Date: Wed, 1 Jan 2014 11:32:54 +0100 Subject: Use md5 from gnulib --- src/pjctl.c | 24 +++++++----------------- 1 file changed, 7 insertions(+), 17 deletions(-) (limited to 'src/pjctl.c') diff --git a/src/pjctl.c b/src/pjctl.c index 66dbd2b..a414baf 100644 --- a/src/pjctl.c +++ b/src/pjctl.c @@ -33,9 +33,7 @@ #include #include -#ifndef NO_CRYPTO -#include -#endif +#include "ext/gnulib/md5.h" enum pjlink_packet_offsets { PJLINK_HEADER = 0, @@ -77,10 +75,8 @@ struct pjctl { int fd; char *password; -#ifndef NO_CRYPTO int need_hash; char hash[32+1]; /* 0-terminated hex as ascii encoded 16 byte hash */ -#endif }; #define ARRAY_SIZE(a) (sizeof(a)/sizeof((a)[0])) @@ -137,17 +133,16 @@ handle_pjlink_error(char *param) return 0; } -#ifndef NO_CRYPTO static void init_hash(struct pjctl *pjctl, const char *salt) { - unsigned char md[MD5_DIGEST_LENGTH]; - MD5_CTX md5; + unsigned char md[MD5_DIGEST_SIZE]; + struct md5_ctx ctx; - MD5_Init(&md5); - MD5_Update(&md5, salt, strlen(salt)); - MD5_Update(&md5, pjctl->password, strlen(pjctl->password)); - MD5_Final(md, &md5); + md5_init_ctx(&ctx); + md5_process_bytes(salt, strlen(salt), &ctx); + md5_process_bytes(pjctl->password, strlen(pjctl->password), &ctx); + md5_finish_ctx(&ctx, md); snprintf(pjctl->hash, sizeof(pjctl->hash), "%02x%02x%02x%02x%02x%02x%02x%02x" @@ -158,7 +153,6 @@ init_hash(struct pjctl *pjctl, const char *salt) md[12], md[13], md[14], md[15]); pjctl->need_hash = 1; } -#endif static int send_next_cmd(struct pjctl *pjctl) @@ -178,7 +172,6 @@ send_next_cmd(struct pjctl *pjctl) memset(&msg, 0, sizeof msg); msg.msg_iov = iov; -#ifndef NO_CRYPTO if (pjctl->need_hash) { pjctl->state = PJCTL_AWAIT_RESPONSE_OR_AUTH_ERR; @@ -186,7 +179,6 @@ send_next_cmd(struct pjctl *pjctl) iov[msg.msg_iovlen].iov_len = 32; msg.msg_iovlen++; } -#endif cmd = pjctl->queue.prev; iov[msg.msg_iovlen].iov_base = cmd->command; @@ -205,7 +197,6 @@ static int handle_setup(struct pjctl *pjctl, char *data, int len) { switch (data[PJLINK_PARAMETER]) { -#ifndef NO_CRYPTO case '1': if (pjctl->password == NULL) { fprintf(stderr, @@ -216,7 +207,6 @@ handle_setup(struct pjctl *pjctl, char *data, int len) goto err; init_hash(pjctl, &data[PJLINK_PARAMETER+2]); break; -#endif case '0': /* No authentication */ break; -- cgit