summaryrefslogtreecommitdiffstats
path: root/src/lib
diff options
context:
space:
mode:
authorJohn Kohl <jtkohl@mit.edu>1990-02-05 12:04:13 +0000
committerJohn Kohl <jtkohl@mit.edu>1990-02-05 12:04:13 +0000
commitd69f0ed88e08517ae43ed3f9032cb1e3edac9feb (patch)
tree3959bf29cdcd1fc7df561419bf993efc5eb16391 /src/lib
parent79d357caecbb773d39b865cb6b2e136490471086 (diff)
downloadkrb5-d69f0ed88e08517ae43ed3f9032cb1e3edac9feb.tar.gz
krb5-d69f0ed88e08517ae43ed3f9032cb1e3edac9feb.tar.xz
krb5-d69f0ed88e08517ae43ed3f9032cb1e3edac9feb.zip
*** empty log message ***
git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@269 dc483132-0cff-0310-8789-dd5450dbe970
Diffstat (limited to 'src/lib')
-rw-r--r--src/lib/kdb/verify_mky.c67
1 files changed, 67 insertions, 0 deletions
diff --git a/src/lib/kdb/verify_mky.c b/src/lib/kdb/verify_mky.c
new file mode 100644
index 000000000..6937c16a5
--- /dev/null
+++ b/src/lib/kdb/verify_mky.c
@@ -0,0 +1,67 @@
+/*
+ * $Source$
+ * $Author$
+ *
+ * Copyright 1990 by the Massachusetts Institute of Technology.
+ *
+ * For copying and distribution information, please see the file
+ * <krb5/mit-copyright.h>.
+ *
+ * krb5_db_verify_master_key();
+ */
+
+#if !defined(lint) && !defined(SABER)
+static char rcsid_verify_mky_c[] =
+"$Id$";
+#endif /* !lint & !SABER */
+
+#include <krb5/copyright.h>
+#include <krb5/krb5.h>
+#include <krb5/kdb.h>
+#include <krb5/krb5_err.h>
+#include <krb5/kdb5_err.h>
+#include <errno.h>
+
+krb5_error_code
+krb5_db_verify_master_key(mprinc, mkey)
+krb5_principal mprinc;
+krb5_keyblock *mkey;
+{
+ krb5_error_code retval;
+ krb5_db_entry master_entry;
+ int nprinc, more;
+ krb5_encrypt_block eblock;
+ extern krb5_encrypt_block master_encblock;
+ krb5_keyblock tempkey;
+
+ nprinc = 1;
+ if (retval = krb5_db_get_principal(mprinc, &master_entry, &nprinc, &more))
+ return(retval);
+
+ if (nprinc != 1) {
+ if (nprinc)
+ krb5_db_free_principal(&master_entry, nprinc);
+ return(KRB5_KDB_NOMASTERKEY);
+ } else if (more) {
+ krb5_db_free_principal(&master_entry, nprinc);
+ return(KRB5KDC_ERR_PRINCIPAL_NOT_UNIQUE);
+ }
+
+ eblock = master_encblock;
+
+ /* do any necessary key pre-processing */
+ if (retval = (*eblock.crypto_entry->process_key)(&eblock, mkey)) {
+ return(retval);
+ }
+ if (retval = krb5_kdb_decrypt_key(&master_entry.key, &tempkey, &eblock)) {
+ (void) (*eblock.crypto_entry->finish_key)(&eblock);
+ return retval;
+ }
+ if (!bcmp(mkey->contents, tempkey.contents, mkey->length)) {
+ retval = KRB5_KDB_BADMASTERKEY;
+ (void) (*eblock.crypto_entry->finish_key)(&eblock);
+ } else
+ retval = (*eblock.crypto_entry->finish_key)(&eblock);
+
+ return retval;
+}