summaryrefslogtreecommitdiffstats
path: root/src/lib/kdb/decrypt_key.c
diff options
context:
space:
mode:
authorJohn Kohl <jtkohl@mit.edu>1990-02-07 13:29:19 +0000
committerJohn Kohl <jtkohl@mit.edu>1990-02-07 13:29:19 +0000
commit2e42bc8df8785a68db35edefe02437d92f74d541 (patch)
tree66cea6585283178ce2d18d7767ea6f9b41563848 /src/lib/kdb/decrypt_key.c
parent280ea5884dcede5f654149c25b406596e7737fe8 (diff)
downloadkrb5-2e42bc8df8785a68db35edefe02437d92f74d541.tar.gz
krb5-2e42bc8df8785a68db35edefe02437d92f74d541.tar.xz
krb5-2e42bc8df8785a68db35edefe02437d92f74d541.zip
*** empty log message ***
git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@296 dc483132-0cff-0310-8789-dd5450dbe970
Diffstat (limited to 'src/lib/kdb/decrypt_key.c')
-rw-r--r--src/lib/kdb/decrypt_key.c62
1 files changed, 62 insertions, 0 deletions
diff --git a/src/lib/kdb/decrypt_key.c b/src/lib/kdb/decrypt_key.c
new file mode 100644
index 000000000..53ffa8015
--- /dev/null
+++ b/src/lib/kdb/decrypt_key.c
@@ -0,0 +1,62 @@
+/*
+ * $Source$
+ * $Author$
+ *
+ * Copyright 1990 by the Massachusetts Institute of Technology.
+ *
+ * For copying and distribution information, please see the file
+ * <krb5/mit-copyright.h>.
+ *
+ * krb5_kdb_encrypt_key(), krb5_kdb_decrypt_key functions
+ */
+
+#if !defined(lint) && !defined(SABER)
+static char rcsid_decrypt_key_c [] =
+"$Id$";
+#endif /* !lint & !SABER */
+
+#include <krb5/copyright.h>
+#include <krb5/krb5.h>
+#include <krb5/kdb5_err.h>
+#include <krb5/ext-proto.h>
+#include <errno.h>
+
+
+krb5_error_code
+krb5_kdb_decrypt_key(in, out, eblock)
+krb5_keyblock *in;
+krb5_keyblock *out;
+krb5_encrypt_block *eblock;
+{
+ krb5_error_code retval;
+
+ *out = *in;
+ out->length = krb5_encrypt_size(in->length, eblock->crypto_entry);
+ out->contents = (krb5_octet *)malloc(out->length);
+ if (!out->contents) {
+ out->contents = 0;
+ out->length = 0;
+ return ENOMEM;
+ }
+ if (retval = (*eblock->crypto_entry->
+ decrypt_func)((krb5_pointer) in->contents,
+ (krb5_pointer) out->contents,
+ in->length, eblock)) {
+ free((char *)out->contents);
+ out->contents = 0;
+ out->length = 0;
+ return retval;
+ }
+ out->length -= sizeof(out->length);
+ if (out->length < 0) {
+ free((char *)out->contents);
+ out->contents = 0;
+ out->length = 0;
+ return KRB5_KDB_INVALIDKEYSIZE;
+ }
+ /* shift key down to beginning of contents, and ignore extra wasted
+ space */
+ bcopy(out->contents, ((krb5_pointer) out->contents ) + sizeof(out->length),
+ out->length);
+ return retval;
+}