#ifndef lint
static const char rcsid[] _U_ =
"@(#) $Header: /tcpdump/master/tcpdump/signature.c,v 1.2 2008-09-22 20:22:10 guy Exp $ (LBL)";
#endif
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#include <tcpdump-stdinc.h>
#include <string.h>
#include "interface.h"
#include "signature.h"
#ifdef HAVE_LIBCRYPTO
#include <CommonCrypto/CommonDigest.h>
#endif
const struct tok signature_check_values[] = {
{ SIGNATURE_VALID, "valid"},
{ SIGNATURE_INVALID, "invalid"},
{ CANT_CHECK_SIGNATURE, "unchecked"},
{ 0, NULL }
};
#ifdef HAVE_LIBCRYPTO
static void
signature_compute_hmac_md5(const u_int8_t *text, int text_len, unsigned char *key,
unsigned int key_len, u_int8_t *digest)
{
CC_MD5_CTX context;
unsigned char k_ipad[65];
unsigned char k_opad[65];
unsigned char tk[16];
int i;
if (key_len > 64) {
CC_MD5_CTX tctx;
CC_MD5_Init(&tctx);
CC_MD5_Update(&tctx, key, key_len);
CC_MD5_Final(tk, &tctx);
key = tk;
key_len = 16;
}
memset(k_ipad, 0, sizeof k_ipad);
memset(k_opad, 0, sizeof k_opad);
memcpy(k_ipad, key, key_len);
memcpy(k_opad, key, key_len);
for (i=0; i<64; i++) {
k_ipad[i] ^= 0x36;
k_opad[i] ^= 0x5c;
}
CC_MD5_Init(&context);
CC_MD5_Update(&context, k_ipad, 64);
CC_MD5_Update(&context, text, text_len);
CC_MD5_Final(digest, &context);
CC_MD5_Init(&context);
CC_MD5_Update(&context, k_opad, 64);
CC_MD5_Update(&context, digest, 16);
CC_MD5_Final(digest, &context);
}
#endif
#ifdef HAVE_LIBCRYPTO
int
signature_verify (const u_char *pptr, u_int plen, u_char *sig_ptr)
{
u_int8_t rcvsig[16];
u_int8_t sig[16];
unsigned int i;
memcpy(rcvsig, sig_ptr, sizeof(rcvsig));
memset(sig_ptr, 0, sizeof(rcvsig));
if (!sigsecret) {
return (CANT_CHECK_SIGNATURE);
}
signature_compute_hmac_md5(pptr, plen, (unsigned char *)sigsecret,
strlen(sigsecret), sig);
if (memcmp(rcvsig, sig, sizeof(sig)) == 0) {
return (SIGNATURE_VALID);
} else {
for (i = 0; i < sizeof(sig); ++i) {
(void)printf("%02x", sig[i]);
}
return (SIGNATURE_INVALID);
}
}
#endif