xref: /netbsd-src/crypto/external/bsd/heimdal/dist/lib/hdb/test_mkey.c (revision d3273b5b76f5afaafe308cead5511dbb8df8c5e9)
1 /*	$NetBSD: test_mkey.c,v 1.2 2017/01/28 21:31:48 christos Exp $	*/
2 
3 
4 #include "hdb_locl.h"
5 #include <krb5/getarg.h>
6 #include <krb5/base64.h>
7 
8 static char *mkey_file;
9 static int help_flag;
10 static int version_flag;
11 
12 struct getargs args[] = {
13     { "mkey-file",	0,      arg_string, &mkey_file,    NULL, NULL },
14     { "help",		'h',	arg_flag,   &help_flag,    NULL, NULL },
15     { "version",	0,	arg_flag,   &version_flag, NULL, NULL }
16 };
17 
18 static int num_args = sizeof(args) / sizeof(args[0]);
19 
20 int
main(int argc,char ** argv)21 main(int argc, char **argv)
22 {
23     krb5_context context;
24     int ret, o = 0;
25 
26     setprogname(argv[0]);
27 
28     if(getarg(args, num_args, argc, argv, &o))
29 	krb5_std_usage(1, args, num_args);
30 
31     if(help_flag)
32 	krb5_std_usage(0, args, num_args);
33 
34     if(version_flag){
35 	print_version(NULL);
36 	exit(0);
37     }
38 
39     ret = krb5_init_context(&context);
40     if (ret)
41 	errx(1, "krb5_init_context failed: %d", ret);
42 
43     if (mkey_file) {
44         hdb_master_key mkey;
45 
46 	ret = hdb_read_master_key(context, mkey_file, &mkey);
47 	if (ret)
48 	    krb5_err(context, 1, ret, "failed to read master key %s", mkey_file);
49 
50 	hdb_free_master_key(context, mkey);
51     } else
52       krb5_errx(context, 1, "no command option given");
53 
54     krb5_free_context(context);
55 
56     return 0;
57 }
58