(main): parse arguments, config file and read master key iff there's
one. git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@3414 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
@@ -37,8 +37,31 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "admin_locl.h"
|
#include "admin_locl.h"
|
||||||
|
#include <getarg.h>
|
||||||
#include <sl.h>
|
#include <sl.h>
|
||||||
|
|
||||||
|
RCSID("$Id$");
|
||||||
|
|
||||||
|
static char *config_file;
|
||||||
|
static char *keyfile;
|
||||||
|
static int help_flag;
|
||||||
|
static int version_flag;
|
||||||
|
|
||||||
|
static struct getargs args[] = {
|
||||||
|
{
|
||||||
|
"config-file", 'c', arg_string, &config_file,
|
||||||
|
"location of config file", "file"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key-file", 'k', arg_string, &keyfile,
|
||||||
|
"location of master key file", "file"
|
||||||
|
},
|
||||||
|
{ "help", 'h', arg_flag, &help_flag },
|
||||||
|
{ "version", 'v', arg_flag, &version_flag }
|
||||||
|
};
|
||||||
|
|
||||||
|
static int num_args = sizeof(args) / sizeof(args[0]);
|
||||||
|
|
||||||
static SL_cmd commands[] = {
|
static SL_cmd commands[] = {
|
||||||
{ "add_new_key", add_new_key, "add_new_key principal", "" },
|
{ "add_new_key", add_new_key, "add_new_key principal", "" },
|
||||||
{ "ank", NULL, NULL, NULL },
|
{ "ank", NULL, NULL, NULL },
|
||||||
@@ -90,9 +113,60 @@ set_db(int argc, char **argv)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
usage(int ret)
|
||||||
|
{
|
||||||
|
arg_printusage (args, num_args, "");
|
||||||
|
exit (ret);
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
main(int argc, char **argv)
|
main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
|
krb5_error_code ret;
|
||||||
|
krb5_config_section *cf;
|
||||||
|
int optind = 0;
|
||||||
|
int e;
|
||||||
|
EncryptionKey key;
|
||||||
|
|
||||||
|
set_progname(argv[0]);
|
||||||
|
|
||||||
|
while((e = getarg(args, num_args, argc, argv, &optind)))
|
||||||
|
warnx("error at argument `%s'", argv[optind]);
|
||||||
|
|
||||||
|
if (help_flag)
|
||||||
|
usage (0);
|
||||||
|
|
||||||
|
if (version_flag)
|
||||||
|
krb5_errx(context, 0, "%s", heimdal_version);
|
||||||
|
|
||||||
|
argc -= optind;
|
||||||
|
argv += optind;
|
||||||
|
|
||||||
|
if (argc != 0)
|
||||||
|
usage (1);
|
||||||
|
|
||||||
krb5_init_context(&context);
|
krb5_init_context(&context);
|
||||||
|
|
||||||
|
if (config_file == NULL)
|
||||||
|
config_file = HDB_DB_DIR "/kdc.conf";
|
||||||
|
|
||||||
|
if(krb5_config_parse_file(config_file, &cf) == 0) {
|
||||||
|
const char *p = krb5_config_get_string (cf, "kdc", "key-file", NULL);
|
||||||
|
if (p)
|
||||||
|
keyfile = strdup(p);
|
||||||
|
}
|
||||||
|
|
||||||
|
ret = hdb_read_master_key(context, keyfile, &key);
|
||||||
|
if (ret && ret != ENOENT)
|
||||||
|
krb5_err(context, 1, ret, "Failed to open master key file");
|
||||||
|
if(ret == 0){
|
||||||
|
set_master_key(key);
|
||||||
|
memset(key.keyvalue.data, 0, key.keyvalue.length);
|
||||||
|
free_EncryptionKey(&key);
|
||||||
|
krb5_warnx (context, "Database is encrypted");
|
||||||
|
}else
|
||||||
|
krb5_warnx (context, "Database is not encrypted");
|
||||||
|
|
||||||
return sl_loop(commands, "kdb_edit> ") != 0;
|
return sl_loop(commands, "kdb_edit> ") != 0;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user