krb5_db_entry *));
static krb5_error_code dump_k5beta6_iterator PROTOTYPE((krb5_pointer,
krb5_db_entry *));
+static krb5_error_code dump_k5beta6_iterator_ext PROTOTYPE((krb5_pointer,
+ krb5_db_entry *,
+ int));
static krb5_error_code dump_k5beta7_princ PROTOTYPE((krb5_pointer,
krb5_db_entry *));
+static krb5_error_code dump_k5beta7_princ_ext PROTOTYPE((krb5_pointer,
+ krb5_db_entry *,
+ int));
+static krb5_error_code dump_k5beta7_princ_withpolicy
+ PROTOTYPE((krb5_pointer, krb5_db_entry *));
static krb5_error_code dump_ov_princ PROTOTYPE((krb5_pointer,
krb5_db_entry *));
static void dump_k5beta7_policy PROTOTYPE((void *, osa_policy_ent_t));
process_ov_record,
};
+dump_version r1_3_version = {
+ "Kerberos version 5 release 1.3",
+ "kdb5_util load_dump version 5\n",
+ 0,
+ 0,
+ dump_k5beta7_princ_withpolicy,
+ dump_k5beta7_policy,
+ process_k5beta7_record,
+};
+
/* External data */
extern char *current_dbname;
extern krb5_boolean dbactive;
static const char oldoption[] = "-old";
static const char b6option[] = "-b6";
+static const char b7option[] = "-b7";
static const char verboseoption[] = "-verbose";
static const char updateoption[] = "-update";
static const char hashoption[] = "-hash";
dump_k5beta6_iterator(ptr, entry)
krb5_pointer ptr;
krb5_db_entry *entry;
+{
+ return dump_k5beta6_iterator_ext(ptr, entry, 0);
+}
+
+static krb5_error_code
+dump_k5beta6_iterator_ext(ptr, entry, kadm)
+ krb5_pointer ptr;
+ krb5_db_entry *entry;
+ int kadm;
{
krb5_error_code retval;
struct dump_args *arg;
*/
switch (tlp->tl_data_type) {
case KRB5_TL_KADM_DATA:
- skip++;
+ if (kadm)
+ counter++;
+ else
+ skip++;
break;
default:
counter++;
entry->fail_auth_count);
/* Pound out tagged data. */
for (tlp = entry->tl_data; tlp; tlp = tlp->tl_data_next) {
- if (tlp->tl_data_type == KRB5_TL_KADM_DATA)
+ if (tlp->tl_data_type == KRB5_TL_KADM_DATA && !kadm)
continue; /* see above, [krb5-admin/89] */
fprintf(arg->ofile, "%d\t%d\t",
dump_k5beta7_princ(ptr, entry)
krb5_pointer ptr;
krb5_db_entry *entry;
+{
+ return dump_k5beta7_princ_ext(ptr, entry, 0);
+}
+
+static krb5_error_code
+dump_k5beta7_princ_ext(ptr, entry, kadm)
+ krb5_pointer ptr;
+ krb5_db_entry *entry;
+ int kadm;
{
krb5_error_code retval;
struct dump_args *arg;
/* save the callee from matching the name again */
tmp_nnames = arg->nnames;
arg->nnames = 0;
- retval = dump_k5beta6_iterator(ptr, entry);
+ retval = dump_k5beta6_iterator_ext(ptr, entry, kadm);
arg->nnames = tmp_nnames;
}
return retval;
}
+static krb5_error_code
+dump_k5beta7_princ_withpolicy(ptr, entry)
+ krb5_pointer ptr;
+ krb5_db_entry *entry;
+{
+ return dump_k5beta7_princ_ext(ptr, entry, 1);
+}
+
void dump_k5beta7_policy(void *data, osa_policy_ent_t entry)
{
struct dump_args *arg;
/*
* usage is:
- * dump_db [-old] [-b6] [-ov] [-verbose] [filename [principals...]]
+ * dump_db [-old] [-b6] [-b7] [-ov] [-verbose] [filename [principals...]]
*/
void
dump_db(argc, argv)
programname = strrchr(argv[0], (int) '/') + 1;
ofile = (char *) NULL;
error = 0;
- dump = &beta7_version;
+ dump = &r1_3_version;
arglist.verbose = 0;
new_mkey_file = 0;
mkey_convert = 0;
dump = &old_version;
else if (!strcmp(argv[aindex], b6option))
dump = &beta6_version;
+ else if (!strcmp(argv[aindex], b7option))
+ dump = &beta7_version;
else if (!strcmp(argv[aindex], ovoption))
dump = &ov_version;
else if (!strcmp(argv[aindex], verboseoption))
}
/*
- * Usage: load_db [-old] [-ov] [-b6] [-verbose] [-update] [-hash] filename
+ * Usage: load_db [-old] [-ov] [-b6] [-b7] [-verbose] [-update] [-hash]
+ * filename
*/
void
load_db(argc, argv)
load = &old_version;
else if (!strcmp(argv[aindex], b6option))
load = &beta6_version;
+ else if (!strcmp(argv[aindex], b7option))
+ load = &beta7_version;
else if (!strcmp(argv[aindex], ovoption))
load = &ov_version;
else if (!strcmp(argv[aindex], verboseoption))
load = &beta6_version;
else if (strcmp(buf, beta7_version.header) == 0)
load = &beta7_version;
+ else if (strcmp(buf, r1_3_version.header) == 0)
+ load = &r1_3_version;
else if (strncmp(buf, ov_version.header,
strlen(ov_version.header)) == 0)
load = &ov_version;