From: Stefan Metzmacher Date: Mon, 9 Jun 2008 19:57:05 +0000 (+0200) Subject: smb2srv: sign SMB2 Logoff replies X-Git-Url: http://git.samba.org/samba.git/?p=tprouty%2Fsamba.git;a=commitdiff_plain;h=2844e361730a6bc640ea89d0e10059deca1ca867 smb2srv: sign SMB2 Logoff replies metze --- diff --git a/source/smb_server/smb2/sesssetup.c b/source/smb_server/smb2/sesssetup.c index 6e3e963794..9f8765d6e9 100644 --- a/source/smb_server/smb2/sesssetup.c +++ b/source/smb_server/smb2/sesssetup.c @@ -224,11 +224,25 @@ void smb2srv_sesssetup_recv(struct smb2srv_request *req) smb2srv_sesssetup_backend(req, io); } -static NTSTATUS smb2srv_logoff_backend(struct smb2srv_request *req) +static int smb2srv_cleanup_session_destructor(struct smbsrv_session **session) { /* TODO: call ntvfs backends to close file of this session */ - talloc_free(req->session); - req->session = NULL; + DEBUG(0,("free session[%p]\n", *session)); + talloc_free(*session); + return 0; +} + +static NTSTATUS smb2srv_logoff_backend(struct smb2srv_request *req) +{ + struct smbsrv_session **session_ptr; + + /* we need to destroy the session after sending the reply */ + session_ptr = talloc(req, struct smbsrv_session *); + NT_STATUS_HAVE_NO_MEMORY(session_ptr); + + *session_ptr = req->session; + talloc_set_destructor(session_ptr, smb2srv_cleanup_session_destructor); + return NT_STATUS_OK; }