diff options
author | Simo Sorce <simo@redhat.com> | 2012-07-23 18:03:15 -0400 |
---|---|---|
committer | Simo Sorce <simo@redhat.com> | 2012-08-28 08:25:52 +0200 |
commit | cc305c3331c3bcef07eb42e3fb0e7918048128b6 (patch) | |
tree | 7c1c966133ca3572ad54e6ecb4e278ac6d19a735 /proxy/src/mechglue/gss_plugin.c | |
parent | d2c02366ecd3d94ff8c9b6c86696f7d9ada4b0d0 (diff) | |
download | gss-proxy-cc305c3331c3bcef07eb42e3fb0e7918048128b6.tar.gz gss-proxy-cc305c3331c3bcef07eb42e3fb0e7918048128b6.tar.xz gss-proxy-cc305c3331c3bcef07eb42e3fb0e7918048128b6.zip |
Add name handle wrapper
Diffstat (limited to 'proxy/src/mechglue/gss_plugin.c')
-rw-r--r-- | proxy/src/mechglue/gss_plugin.c | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/proxy/src/mechglue/gss_plugin.c b/proxy/src/mechglue/gss_plugin.c index 0c990ad..a64c888 100644 --- a/proxy/src/mechglue/gss_plugin.c +++ b/proxy/src/mechglue/gss_plugin.c @@ -359,7 +359,71 @@ uint32_t gpp_remote_to_local_ctx(uint32_t *minor, gssx_ctx **remote_ctx, xdr_free((xdrproc_t)xdr_gssx_ctx, (char *)(*remote_ctx)); *remote_ctx = NULL; + return maj; +} + +uint32_t gpp_name_to_local(uint32_t *minor, gssx_name *name, + gss_OID mech_type, gss_name_t *mech_name) +{ + uint32_t maj, min; + gss_buffer_desc display_name_buffer = GSS_C_EMPTY_BUFFER; + gss_OID display_name_type = GSS_C_NO_OID; + gss_name_t tmpname = NULL; + + maj = gpm_display_name(minor, name, + &display_name_buffer, + &display_name_type); + if (maj) { + return maj; + } + + maj = gss_import_name(minor, + &display_name_buffer, + display_name_type, + &tmpname); + + (void)gss_release_buffer(&min, &display_name_buffer); + (void)gss_release_oid(&min, &display_name_type); + + if (maj) { + return maj; + } + + if (mech_type != GSS_C_NO_OID) { + /* name for specific mech requested */ + maj = gss_canonicalize_name(minor, + tmpname, + gpp_special_mech(mech_type), + mech_name); + (void)gss_release_name(&min, &tmpname); + } else { + *mech_name = tmpname; + } + + return maj; +} + +uint32_t gpp_local_to_name(uint32_t *minor, + gss_name_t local_name, gssx_name **name) +{ + uint32_t maj, min; + gss_buffer_desc display_name_buffer = GSS_C_EMPTY_BUFFER; + gss_OID display_name_type = GSS_C_NO_OID; + + maj = gss_display_name(minor, local_name, + &display_name_buffer, + &display_name_type); + if (maj) { + return maj; + } + + maj = gpm_import_name(minor, + &display_name_buffer, + display_name_type, + name); + (void)gss_release_buffer(&min, &display_name_buffer); + (void)gss_release_oid(&min, &display_name_type); return maj; } |