summaryrefslogtreecommitdiffstats
path: root/src/lib/gssapi/krb5/copy_ccache.c
diff options
context:
space:
mode:
authorDan Winship <danw@mit.edu>1998-01-30 01:20:11 +0000
committerDan Winship <danw@mit.edu>1998-01-30 01:20:11 +0000
commit39bafbdf1f24be6a6ae8a3b6e71963bbc8c17d5a (patch)
tree1ffce6d63ba73fe89c5377e772efc93931fadde2 /src/lib/gssapi/krb5/copy_ccache.c
parent29763f5e2e510bc7bfe728c6edf6987c2f4cc90b (diff)
downloadkrb5-39bafbdf1f24be6a6ae8a3b6e71963bbc8c17d5a.tar.gz
krb5-39bafbdf1f24be6a6ae8a3b6e71963bbc8c17d5a.tar.xz
krb5-39bafbdf1f24be6a6ae8a3b6e71963bbc8c17d5a.zip
* accept_sec_context.c (rd_and_store_for_creds): Don't mess with
krb5_cc_default--use a new mem-based ccache. * Makefile.in: * gssapi_krb5.h: * copy_ccache.c (gss_krb5_copy_ccache): Routine to copy a gss_cred_id_t (such as a forwarded creds) into an existing krb5_ccache. git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@10389 dc483132-0cff-0310-8789-dd5450dbe970
Diffstat (limited to 'src/lib/gssapi/krb5/copy_ccache.c')
-rw-r--r--src/lib/gssapi/krb5/copy_ccache.c46
1 files changed, 46 insertions, 0 deletions
diff --git a/src/lib/gssapi/krb5/copy_ccache.c b/src/lib/gssapi/krb5/copy_ccache.c
new file mode 100644
index 000000000..39d9bc277
--- /dev/null
+++ b/src/lib/gssapi/krb5/copy_ccache.c
@@ -0,0 +1,46 @@
+#include "gssapiP_krb5.h"
+
+OM_uint32
+gss_krb5_copy_ccache(minor_status, cred_handle, out_ccache)
+ OM_uint32 *minor_status;
+ gss_cred_id_t cred_handle;
+ krb5_ccache out_ccache;
+{
+ OM_uint32 stat;
+ krb5_gss_cred_id_t k5creds;
+ krb5_cc_cursor cursor;
+ krb5_creds creds;
+ krb5_error_code code;
+ krb5_context context;
+
+ /* validate the cred handle */
+ stat = krb5_gss_validate_cred(minor_status, creds);
+ if (stat)
+ return(stat);
+
+ k5creds = (krb5_gss_cred_id_t) cred_handle;
+ if (k5creds->usage == GSS_C_ACCEPT) {
+ *minor_status = (OM_uint32) G_BAD_USAGE;
+ return(GSS_S_FAILURE);
+ }
+
+ if (GSS_ERROR(kg_get_context(minor_status, &context)))
+ return (GSS_S_FAILURE);
+
+ code = krb5_cc_start_seq_get(context, k5creds->ccache, &cursor);
+ if (code) {
+ *minor_status = code;
+ return(GSS_S_FAILURE);
+ }
+ while (!code && !krb5_cc_next_cred(context, k5creds->ccache, &creds, &cursor))
+ code = krb5_cc_store_cred(context, out_ccache, &creds);
+ krb5_cc_end_seq_get(context, k5creds->ccache, &cursor);
+
+ if (code) {
+ *minor_status = code;
+ return(GSS_S_FAILURE);
+ } else {
+ *minor_status = 0;
+ return(GSS_S_COMPLETE);
+ }
+}