[04/10] secur32: Implement DeleteSecurityContext for Kerberos.
Hans Leidekker
hans at codeweavers.com
Mon Oct 16 03:04:57 CDT 2017
Signed-off-by: Hans Leidekker <hans at codeweavers.com>
---
dlls/secur32/kerberos.c | 21 +++++++++++++++++++--
1 file changed, 19 insertions(+), 2 deletions(-)
diff --git a/dlls/secur32/kerberos.c b/dlls/secur32/kerberos.c
index f5f596659b..7704b1590f 100644
--- a/dlls/secur32/kerberos.c
+++ b/dlls/secur32/kerberos.c
@@ -507,10 +507,27 @@ static SECURITY_STATUS SEC_ENTRY kerberos_CompleteAuthToken(CtxtHandle *phContex
/***********************************************************************
* DeleteSecurityContext
*/
-static SECURITY_STATUS SEC_ENTRY kerberos_DeleteSecurityContext(CtxtHandle *phContext)
+static SECURITY_STATUS SEC_ENTRY kerberos_DeleteSecurityContext( CtxtHandle *phContext )
{
- FIXME("(%p)\n", phContext);
+#ifdef HAVE_GSSAPI
+ OM_uint32 ret, minor_status;
+ gss_ctx_id_t ctxt_handle;
+
+ TRACE( "(%p)\n", phContext );
+ if (!phContext) return SEC_E_INVALID_HANDLE;
+ if (!(ctxt_handle = ctxthandle_sspi_to_gss( phContext ))) return SEC_E_OK;
+
+ ret = gss_delete_sec_context( &minor_status, &ctxt_handle, GSS_C_NO_BUFFER );
+ TRACE( "gss_delete_sec_context returned %08x minor status %08x\n", ret, minor_status );
+
+ phContext->dwUpper = 0;
+ phContext->dwLower = 0;
+
+ return status_gss_to_sspi( ret );
+#else
+ FIXME( "(%p)\n", phContext );
return SEC_E_UNSUPPORTED_FUNCTION;
+#endif
}
/***********************************************************************
--
2.11.0
More information about the wine-patches
mailing list