summaryrefslogtreecommitdiffstats
path: root/src/kadmin/cli/keytab.c
diff options
context:
space:
mode:
authorTom Yu <tlyu@mit.edu>1996-11-13 03:35:50 +0000
committerTom Yu <tlyu@mit.edu>1996-11-13 03:35:50 +0000
commit83721dc828e9b018f532ddba3ef240c39b65741f (patch)
treeb2a2ec4e0ae93558f05d266441a79e6d46399d53 /src/kadmin/cli/keytab.c
parentefd599df7705ff16ab16eef35eb760210f541c19 (diff)
downloadkrb5-83721dc828e9b018f532ddba3ef240c39b65741f.tar.gz
krb5-83721dc828e9b018f532ddba3ef240c39b65741f.tar.xz
krb5-83721dc828e9b018f532ddba3ef240c39b65741f.zip
* keytab.c (process_keytab): Retrieve *keytab_str using
krb5_kt_default_name() to avoid global variable nastiness. * kadmin.c (kadmin_startup): Use krb5_kt_set_default_name to change the default keytab name rather than assigning to a library global variable. git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@9394 dc483132-0cff-0310-8789-dd5450dbe970
Diffstat (limited to 'src/kadmin/cli/keytab.c')
-rw-r--r--src/kadmin/cli/keytab.c12
1 files changed, 9 insertions, 3 deletions
diff --git a/src/kadmin/cli/keytab.c b/src/kadmin/cli/keytab.c
index 338206356d..5a47bf159b 100644
--- a/src/kadmin/cli/keytab.c
+++ b/src/kadmin/cli/keytab.c
@@ -23,7 +23,6 @@ static int remove_principal(char *keytab_str, krb5_keytab keytab, char
*princ_str, char *kvno_str);
static char *etype_string(krb5_enctype enctype);
-extern char *krb5_defkeyname;
extern char *whoami;
extern krb5_context context;
extern void *handle;
@@ -45,8 +44,15 @@ int process_keytab(krb5_context context, char **keytab_str,
int code;
if (*keytab_str == NULL) {
- if (! (*keytab_str = strdup(krb5_defkeyname))) {
- com_err(whoami, ENOMEM, "while creating keytab name");
+ char *keytab_str = malloc(BUFSIZ);
+
+ if (keytab_str == NULL) {
+ com_err(whoami, ENOMEM, "while creating default keytab name");
+ return 1;
+ }
+ if ((code = krb5_kt_default_name(context, keytab_str, BUFSIZ))) {
+ com_err(whoami, code, "while copying default keytab name");
+ free(*keytab_str);
return 1;
}
code = krb5_kt_default(context, keytab);