diff options
author | Dan Winship <danw@mit.edu> | 1998-01-30 01:20:11 +0000 |
---|---|---|
committer | Dan Winship <danw@mit.edu> | 1998-01-30 01:20:11 +0000 |
commit | 39bafbdf1f24be6a6ae8a3b6e71963bbc8c17d5a (patch) | |
tree | 1ffce6d63ba73fe89c5377e772efc93931fadde2 /src/lib/gssapi/krb5/copy_ccache.c | |
parent | 29763f5e2e510bc7bfe728c6edf6987c2f4cc90b (diff) | |
download | krb5-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.c | 46 |
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); + } +} |