From cc17ce366a459bf1cb2207a45e5528ea0167b323 Mon Sep 17 00:00:00 2001 From: Jeremy Allison Date: Mon, 12 Nov 2012 16:26:25 -0800 Subject: [PATCH] More for #9374 - Allow smb2.acls torture test to pass against smbd with a POSIX ACLs backend. Change can_delete_directory() to can_delete_directory_fsp(), as we only ever call this from an open directory file handle. This allows us to use OpenDir_fsp() instead of OpenDir(). OpenDir() re-checks the ACL on the directory, which may refuse DIR_LIST permissions. OpenDir_fsp() does not. As this is a file-server internal check to see if the directory actually contains any files before setting delete on close, we can ignore the ACL here (Windows does). --- source3/include/proto.h | 3 +-- source3/lib/dummysmbd.c | 3 +-- source3/locking/locking.c | 3 +-- source3/smbd/dir.c | 15 +++++++++------ 4 files changed, 12 insertions(+), 12 deletions(-) diff --git a/source3/include/proto.h b/source3/include/proto.h index 720f431cc73..189b286dd6c 100644 --- a/source3/include/proto.h +++ b/source3/include/proto.h @@ -1970,8 +1970,7 @@ void cancel_pending_lock_requests_by_fid(files_struct *fsp, enum file_close_type close_type); void send_stat_cache_delete_message(struct messaging_context *msg_ctx, const char *name); -NTSTATUS can_delete_directory(struct connection_struct *conn, - const char *dirname); +NTSTATUS can_delete_directory_fsp(files_struct *fsp); bool change_to_root_user(void); struct event_context *smbd_event_context(void); void contend_level2_oplocks_begin(files_struct *fsp, diff --git a/source3/lib/dummysmbd.c b/source3/lib/dummysmbd.c index 2465e6552bc..0ff0f2e8743 100644 --- a/source3/lib/dummysmbd.c +++ b/source3/lib/dummysmbd.c @@ -44,8 +44,7 @@ void send_stat_cache_delete_message(struct messaging_context *msg_ctx, { } -NTSTATUS can_delete_directory(struct connection_struct *conn, - const char *dirname) +NTSTATUS can_delete_directory_fsp(files_struct *fsp) { return NT_STATUS_OK; } diff --git a/source3/locking/locking.c b/source3/locking/locking.c index 43798477abc..e60c4a883d7 100644 --- a/source3/locking/locking.c +++ b/source3/locking/locking.c @@ -1476,8 +1476,7 @@ NTSTATUS can_set_delete_on_close(files_struct *fsp, uint32 dosmode) return NT_STATUS_ACCESS_DENIED; } - return can_delete_directory(fsp->conn, - fsp->fsp_name->base_name); + return can_delete_directory_fsp(fsp); } return NT_STATUS_OK; diff --git a/source3/smbd/dir.c b/source3/smbd/dir.c index 9108a80c6ca..92be816a4e4 100644 --- a/source3/smbd/dir.c +++ b/source3/smbd/dir.c @@ -1643,16 +1643,19 @@ bool SearchDir(struct smb_Dir *dirp, const char *name, long *poffset) Is this directory empty ? *****************************************************************/ -NTSTATUS can_delete_directory(struct connection_struct *conn, - const char *dirname) +NTSTATUS can_delete_directory_fsp(files_struct *fsp) { NTSTATUS status = NT_STATUS_OK; long dirpos = 0; const char *dname = NULL; char *talloced = NULL; SMB_STRUCT_STAT st; - struct smb_Dir *dir_hnd = OpenDir(talloc_tos(), conn, - dirname, NULL, 0); + struct connection_struct *conn = fsp->conn; + struct smb_Dir *dir_hnd = OpenDir_fsp(talloc_tos(), + conn, + fsp, + NULL, + 0); if (!dir_hnd) { return map_nt_error_from_unix(errno); @@ -1667,12 +1670,12 @@ NTSTATUS can_delete_directory(struct connection_struct *conn, } } - if (!is_visible_file(conn, dirname, dname, &st, True)) { + if (!is_visible_file(conn, fsp->fsp_name->base_name, dname, &st, True)) { TALLOC_FREE(talloced); continue; } - DEBUG(10,("can_delete_directory: got name %s - can't delete\n", + DEBUG(10,("can_delete_directory_fsp: got name %s - can't delete\n", dname )); status = NT_STATUS_DIRECTORY_NOT_EMPTY; break; -- 2.11.4.GIT