/*1* Copyright (c) 1997-2004 Kungliga Tekniska Högskolan2* (Royal Institute of Technology, Stockholm, Sweden).3* All rights reserved.4*5* Redistribution and use in source and binary forms, with or without6* modification, are permitted provided that the following conditions7* are met:8*9* 1. Redistributions of source code must retain the above copyright10* notice, this list of conditions and the following disclaimer.11*12* 2. Redistributions in binary form must reproduce the above copyright13* notice, this list of conditions and the following disclaimer in the14* documentation and/or other materials provided with the distribution.15*16* 3. Neither the name of the Institute nor the names of its contributors17* may be used to endorse or promote products derived from this software18* without specific prior written permission.19*20* THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND21* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE22* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE23* ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE24* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL25* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS26* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)27* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT28* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY29* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF30* SUCH DAMAGE.31*/3233#include "kadmin_locl.h"34#include "kadmin-commands.h"35#include <kadm5/private.h>3637extern int local_flag;3839int40dump(struct dump_options *opt, int argc, char **argv)41{42krb5_error_code ret;43FILE *f;44struct hdb_print_entry_arg parg;45HDB *db = NULL;4647if (!local_flag) {48krb5_warnx(context, "dump is only available in local (-l) mode");49return 0;50}5152db = _kadm5_s_get_db(kadm_handle);5354if (argc == 0)55f = stdout;56else57f = fopen(argv[0], "w");5859if (f == NULL) {60krb5_warn(context, errno, "open: %s", argv[0]);61goto out;62}63ret = db->hdb_open(context, db, O_RDONLY, 0600);64if (ret) {65krb5_warn(context, ret, "hdb_open");66goto out;67}6869if (!opt->format_string || strcmp(opt->format_string, "Heimdal") == 0) {70parg.fmt = HDB_DUMP_HEIMDAL;71} else if (opt->format_string && strcmp(opt->format_string, "MIT") == 0) {72parg.fmt = HDB_DUMP_MIT;73fprintf(f, "kdb5_util load_dump version 5\n"); /* 5||6, either way */74} else if (opt->format_string) {75/* Open the format string as a MIT mkey file. */76ret = hdb_read_master_key(context, opt->format_string, &db->hdb_mit_key);77if (ret)78krb5_errx(context, 1, "Cannot open MIT mkey file");79db->hdb_mit_key_set = 1;80parg.fmt = HDB_DUMP_MIT;81opt->decrypt_flag = 1;82fprintf(f, "kdb5_util load_dump version 5\n"); /* 5||6, either way */83} else {84krb5_errx(context, 1, "Supported dump formats: Heimdal and MIT");85}86parg.out = f;87hdb_foreach(context, db, opt->decrypt_flag ? HDB_F_DECRYPT : 0,88hdb_print_entry, &parg);8990db->hdb_close(context, db);91out:92if(f && f != stdout)93fclose(f);94return 0;95}969798