1999-11-17 07:29:08 +01:00
|
|
|
#include "includes.h"
|
1999-11-24 14:26:21 +01:00
|
|
|
RCSID("$Id: fingerprint.c,v 1.3 1999/11/24 00:26:01 deraadt Exp $");
|
1999-11-17 07:29:08 +01:00
|
|
|
|
|
|
|
#include "ssh.h"
|
|
|
|
#include "xmalloc.h"
|
1999-11-19 02:05:01 +01:00
|
|
|
|
|
|
|
#ifdef HAVE_OPENSSL
|
|
|
|
#include <openssl/md5.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_SSL
|
1999-11-17 07:29:08 +01:00
|
|
|
#include <ssl/md5.h>
|
1999-11-19 02:05:01 +01:00
|
|
|
#endif
|
1999-11-17 07:29:08 +01:00
|
|
|
|
|
|
|
#define FPRINT "%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x"
|
|
|
|
|
1999-11-24 14:26:21 +01:00
|
|
|
/*
|
|
|
|
* Generate key fingerprint in ascii format.
|
|
|
|
* Based on ideas and code from Bjoern Groenvall <bg@sics.se>
|
|
|
|
*/
|
1999-11-17 07:29:08 +01:00
|
|
|
char *
|
|
|
|
fingerprint(BIGNUM *e, BIGNUM *n)
|
|
|
|
{
|
1999-11-24 14:26:21 +01:00
|
|
|
static char retval[80];
|
|
|
|
MD5_CTX md;
|
|
|
|
unsigned char d[16];
|
|
|
|
char *buf;
|
|
|
|
int nlen, elen;
|
1999-11-17 07:29:08 +01:00
|
|
|
|
|
|
|
nlen = BN_num_bytes(n);
|
|
|
|
elen = BN_num_bytes(e);
|
|
|
|
|
|
|
|
buf = xmalloc(nlen + elen);
|
|
|
|
|
|
|
|
BN_bn2bin(n, buf);
|
|
|
|
BN_bn2bin(e, buf + nlen);
|
|
|
|
|
|
|
|
MD5_Init(&md);
|
|
|
|
MD5_Update(&md, buf, nlen + elen);
|
|
|
|
MD5_Final(d, &md);
|
|
|
|
snprintf(retval, sizeof(retval), FPRINT,
|
1999-11-24 14:26:21 +01:00
|
|
|
d[0], d[1], d[2], d[3], d[4], d[5], d[6], d[7],
|
|
|
|
d[8], d[9], d[10], d[11], d[12], d[13], d[14], d[15]);
|
1999-11-17 07:29:08 +01:00
|
|
|
memset(buf, 0, nlen + elen);
|
|
|
|
xfree(buf);
|
|
|
|
return retval;
|
|
|
|
}
|