summaryrefslogtreecommitdiffstats
path: root/src/lib/crypto/md5
diff options
context:
space:
mode:
authorPaul Park <pjpark@mit.edu>1995-07-07 21:04:06 +0000
committerPaul Park <pjpark@mit.edu>1995-07-07 21:04:06 +0000
commit45bc0f1a97107556fabb19d2186eaa1bc99bee94 (patch)
treea495ed541b51bd24263839670749b1fbcbd9fc65 /src/lib/crypto/md5
parente54232a4f64f8ae87123943b27812408d19d6dd8 (diff)
downloadkrb5-45bc0f1a97107556fabb19d2186eaa1bc99bee94.tar.gz
krb5-45bc0f1a97107556fabb19d2186eaa1bc99bee94.tar.xz
krb5-45bc0f1a97107556fabb19d2186eaa1bc99bee94.zip
Add checksum verification procedure and dispatch
git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@6258 dc483132-0cff-0310-8789-dd5450dbe970
Diffstat (limited to 'src/lib/crypto/md5')
-rw-r--r--src/lib/crypto/md5/md5glue.c38
1 files changed, 34 insertions, 4 deletions
diff --git a/src/lib/crypto/md5/md5glue.c b/src/lib/crypto/md5/md5glue.c
index db2351fbfc..afaa721fc7 100644
--- a/src/lib/crypto/md5/md5glue.c
+++ b/src/lib/crypto/md5/md5glue.c
@@ -2,10 +2,6 @@
#include "rsa-md5.h"
krb5_error_code
-md5_sum_func KRB5_NPROTOTYPE((krb5_pointer in, size_t in_length,
- krb5_pointer seed, size_t seed_length, krb5_checksum *outcksum));
-
-krb5_error_code
md5_sum_func(in, in_length, seed, seed_length, outcksum)
krb5_pointer in;
size_t in_length;
@@ -29,9 +25,43 @@ krb5_checksum FAR *outcksum;
return 0;
}
+krb5_error_code
+md5_verify_func(cksum, in, in_length, seed, seed_length)
+krb5_checksum FAR *cksum;
+krb5_pointer in;
+size_t in_length;
+krb5_pointer seed;
+size_t seed_length;
+{
+ krb5_octet *input = (krb5_octet *)in;
+ MD5_CTX working;
+ krb5_error_code retval;
+
+ retval = 0;
+ if (cksum->checksum_type == CKSUMTYPE_RSA_MD5) {
+ if (cksum->length == RSA_MD5_CKSUM_LENGTH) {
+ MD5Init(&working);
+ MD5Update(&working, input, in_length);
+ MD5Final(&working);
+
+ if (memcmp((char *) cksum->contents,
+ (char *) &working.digest[0],
+ RSA_MD5_CKSUM_LENGTH))
+ retval = KRB5KRB_AP_ERR_BAD_INTEGRITY;
+ memset((char *)&working, 0, sizeof(working));
+ }
+ else
+ retval = KRB5KRB_AP_ERR_BAD_INTEGRITY;
+ }
+ else
+ retval = KRB5KRB_AP_ERR_INAPP_CKSUM;
+ return retval;
+}
+
krb5_checksum_entry rsa_md5_cksumtable_entry = {
0,
md5_sum_func,
+ md5_verify_func,
RSA_MD5_CKSUM_LENGTH,
1, /* is collision proof */
0, /* doesn't use key */