From c0d36aa00aa1daa1f6f0eff3650e801223470c2d Mon Sep 17 00:00:00 2001 From: Ben Harris Date: Sat, 10 Sep 2005 16:19:53 +0000 Subject: [PATCH] Implement hmac-sha1-96. It's RECOMMENDED in the current transport draft, and we don't have any strong reason not to implement it, for all that it's rather pointless. [originally from svn r6284] --- ssh.c | 4 ++-- ssh.h | 2 ++ sshsha.c | 32 ++++++++++++++++++++++++++++++++ 3 files changed, 36 insertions(+), 2 deletions(-) diff --git a/ssh.c b/ssh.c index 75610c67..d1b7acc7 100644 --- a/ssh.c +++ b/ssh.c @@ -462,10 +462,10 @@ static void do_ssh2_authconn(Ssh ssh, unsigned char *in, int inlen, const static struct ssh_signkey *hostkey_algs[] = { &ssh_rsa, &ssh_dss }; const static struct ssh_mac *macs[] = { - &ssh_hmac_sha1, &ssh_hmac_md5 + &ssh_hmac_sha1, &ssh_hmac_sha1_96, &ssh_hmac_md5 }; const static struct ssh_mac *buggymacs[] = { - &ssh_hmac_sha1_buggy, &ssh_hmac_md5 + &ssh_hmac_sha1_buggy, &ssh_hmac_sha1_96_buggy, &ssh_hmac_md5 }; static void *ssh_comp_none_init(void) diff --git a/ssh.h b/ssh.h index 43060c92..8357f0c4 100644 --- a/ssh.h +++ b/ssh.h @@ -269,6 +269,8 @@ extern const struct ssh_signkey ssh_rsa; extern const struct ssh_mac ssh_hmac_md5; extern const struct ssh_mac ssh_hmac_sha1; extern const struct ssh_mac ssh_hmac_sha1_buggy; +extern const struct ssh_mac ssh_hmac_sha1_96; +extern const struct ssh_mac ssh_hmac_sha1_96_buggy; /* diff --git a/sshsha.c b/sshsha.c index 29908b62..b3860b69 100644 --- a/sshsha.c +++ b/sshsha.c @@ -301,6 +301,22 @@ static int sha1_verify(void *handle, unsigned char *blk, int len, return !memcmp(correct, blk + len, 20); } +static void sha1_96_generate(void *handle, unsigned char *blk, int len, + unsigned long seq) +{ + unsigned char full[20]; + sha1_do_hmac(handle, blk, len, seq, full); + memcpy(blk + len, full, 12); +} + +static int sha1_96_verify(void *handle, unsigned char *blk, int len, + unsigned long seq) +{ + unsigned char correct[20]; + sha1_do_hmac(handle, blk, len, seq, correct); + return !memcmp(correct, blk + len, 12); +} + void hmac_sha1_simple(void *key, int keylen, void *data, int datalen, unsigned char *output) { SHA_State states[2]; @@ -322,6 +338,14 @@ const struct ssh_mac ssh_hmac_sha1 = { "HMAC-SHA1" }; +const struct ssh_mac ssh_hmac_sha1_96 = { + sha1_make_context, sha1_free_context, sha1_key, + sha1_96_generate, sha1_96_verify, + "hmac-sha1-96", + 12, + "HMAC-SHA1-96" +}; + const struct ssh_mac ssh_hmac_sha1_buggy = { sha1_make_context, sha1_free_context, sha1_key_buggy, sha1_generate, sha1_verify, @@ -329,3 +353,11 @@ const struct ssh_mac ssh_hmac_sha1_buggy = { 20, "bug-compatible HMAC-SHA1" }; + +const struct ssh_mac ssh_hmac_sha1_96_buggy = { + sha1_make_context, sha1_free_context, sha1_key_buggy, + sha1_96_generate, sha1_96_verify, + "hmac-sha1-96", + 12, + "bug-compatible HMAC-SHA1-96" +};