From: Jeremy Allison Date: Mon, 23 Apr 2012 23:19:50 +0000 (-0700) Subject: Fix bug #8882 - Broken processing of %U with vfs_full_audit when force user is set. X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=0529cf9d039d0ae449f4b167952b42b2039238be;p=thirdparty%2Fsamba.git Fix bug #8882 - Broken processing of %U with vfs_full_audit when force user is set. When doing a "force user" we need to remember what the "sanitized_username" was from the original connect. --- diff --git a/source3/smbd/service.c b/source3/smbd/service.c index bc2cdaf2d85..2de93848935 100644 --- a/source3/smbd/service.c +++ b/source3/smbd/service.c @@ -746,6 +746,14 @@ connection_struct *make_connection_snum(struct smbd_server_connection *sconn, return NULL; } + /* We don't want to replace the original sanitized_username + as it is the original user given in the connect attempt. + This is used in '%U' substitutions. */ + TALLOC_FREE(forced_serverinfo->sanitized_username); + forced_serverinfo->sanitized_username = + talloc_move(forced_serverinfo, + &conn->server_info->sanitized_username); + TALLOC_FREE(conn->server_info); conn->server_info = forced_serverinfo;