summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorTom Yu <tlyu@mit.edu>2003-02-25 23:55:50 +0000
committerTom Yu <tlyu@mit.edu>2003-02-25 23:55:50 +0000
commitd1eae1cd49d3b8aac3092b636bf84b2092f014fb (patch)
tree9365d138f4068259db32a7dda8c0ecb8b502ed23 /src
parentaa52218d22c19ba97720a69bfcbfe5e23586f6e9 (diff)
downloadkrb5-d1eae1cd49d3b8aac3092b636bf84b2092f014fb.tar.gz
krb5-d1eae1cd49d3b8aac3092b636bf84b2092f014fb.tar.xz
krb5-d1eae1cd49d3b8aac3092b636bf84b2092f014fb.zip
Thanks, similar patch applied
* set_ccache.c (gss_krb5_ccache_name): Don't return a pointer to freed memory. ticket: 1346 git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@15205 dc483132-0cff-0310-8789-dd5450dbe970
Diffstat (limited to 'src')
-rw-r--r--src/lib/gssapi/krb5/ChangeLog5
-rw-r--r--src/lib/gssapi/krb5/set_ccache.c53
2 files changed, 52 insertions, 6 deletions
diff --git a/src/lib/gssapi/krb5/ChangeLog b/src/lib/gssapi/krb5/ChangeLog
index 26afbfa72..65ecfc1f5 100644
--- a/src/lib/gssapi/krb5/ChangeLog
+++ b/src/lib/gssapi/krb5/ChangeLog
@@ -1,3 +1,8 @@
+2003-02-25 Tom Yu <tlyu@mit.edu>
+
+ * set_ccache.c (gss_krb5_ccache_name): Don't return a pointer to
+ freed memory.
+
2003-02-24 Tom Yu <tlyu@mit.edu>
* gssapi_krb5.c (kg_get_defcred): Revert previous; it's probably
diff --git a/src/lib/gssapi/krb5/set_ccache.c b/src/lib/gssapi/krb5/set_ccache.c
index ced403d9c..9a612201b 100644
--- a/src/lib/gssapi/krb5/set_ccache.c
+++ b/src/lib/gssapi/krb5/set_ccache.c
@@ -1,3 +1,33 @@
+/*
+ * lib/gssapi/krb5/set_ccache.c
+ *
+ * Copyright 1999, 2003 by the Massachusetts Institute of Technology.
+ * All Rights Reserved.
+ *
+ * Export of this software from the United States of America may
+ * require a specific license from the United States Government.
+ * It is the responsibility of any person or organization contemplating
+ * export to obtain such a license before exporting.
+ *
+ * WITHIN THAT CONSTRAINT, permission to use, copy, modify, and
+ * distribute this software and its documentation for any purpose and
+ * without fee is hereby granted, provided that the above copyright
+ * notice appear in all copies and that both that copyright notice and
+ * this permission notice appear in supporting documentation, and that
+ * the name of M.I.T. not be used in advertising or publicity pertaining
+ * to distribution of the software without specific, written prior
+ * permission. Furthermore if you modify this software you must label
+ * your software as modified software and not distribute it in such a
+ * fashion that it might be confused with the original M.I.T. software.
+ * M.I.T. makes no representations about the suitability of
+ * this software for any purpose. It is provided "as is" without express
+ * or implied warranty.
+ *
+ * Set ccache name used by gssapi, and optionally obtain old ccache
+ * name. Caller should not free returned name.
+ */
+
+#include <string.h>
#include "gssapiP_krb5.h"
OM_uint32 KRB5_CALLCONV
@@ -9,12 +39,27 @@ gss_krb5_ccache_name(minor_status, name, out_name)
krb5_context context;
krb5_error_code retval;
OM_uint32 foo_stat;
+ static char *oldname = NULL;
+ const char *tmpname = NULL;
if (GSS_ERROR(kg_get_context(minor_status, &context)))
return (GSS_S_FAILURE);
- if (out_name)
- *out_name = krb5_cc_default_name(context);
+ if (out_name) {
+ if (oldname != NULL)
+ free(oldname);
+ /*
+ * Save copy of previous default ccname, since
+ * cc_set_default_name will free it and we don't want
+ * to hang on to a pointer to freed memory.
+ */
+ tmpname = krb5_cc_default_name(context);
+ oldname = malloc(strlen(tmpname) + 1);
+ if (oldname == NULL)
+ return GSS_S_FAILURE;
+ strcpy(oldname, tmpname);
+ *out_name = oldname;
+ }
retval = krb5_cc_set_default_name(context, name);
if (retval) {
@@ -24,7 +69,3 @@ gss_krb5_ccache_name(minor_status, name, out_name)
kg_release_defcred(&foo_stat);
return GSS_S_COMPLETE;
}
-
-
-
-