1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-13 13:18:06 +03:00

s3: smbd: Move the setting of the destructor of struct smb_Dir * up two levels.

Previously, open_dir_safely() called OpenDir_internal() which
set the destructor.

Move setting the destructor into the callers of open_dir_safely()
as this will allow us to have different destructors for handle-based
calls.

The reason this is important is that I have a follow up patchset
that depends on this which makes all client directory enumerations
handle-based, calling OpenDir_fsp() only, and so the destructor there
will take care of the fsp back pointer.

Trying to keep a common destructor for handle-based and non-handle
based calls broke my brain when trying to separate the handle-based
calls from the non-handle based ones in my later patchset.

NB. The change in OpenDir_fsp() isn't a logic change as instead
of doing an early return from a function that sets the destructor,
we now fallthrough to setting the destructor then return, which
is identical.

Eventually the whole codepath using the fallback for non-handle
opens inside dptr_create() will go away and this simplifies the
code immensely. Some short term pain for long-term gain :-).

Added doxygen documentation as requested.

Signed-off-by: Jeremy Allison <jra@samba.org>
Reviewed-by: Andreas Schneider <asn@samba.org>
This commit is contained in:
Jeremy Allison 2019-07-17 09:11:25 -07:00 committed by Andreas Schneider
parent 41c94b8b1f
commit d144108972

View File

@ -90,6 +90,7 @@ static struct smb_Dir *open_dir_safely(TALLOC_CTX *ctx,
const struct smb_filename *smb_dname,
const char *wcard,
uint32_t attr);
static int smb_Dir_destructor(struct smb_Dir *dirp);
#define INVALID_DPTR_KEY (-3)
@ -342,6 +343,10 @@ static struct smb_Dir *open_dir_with_privilege(connection_struct *conn,
dir_hnd = open_dir_safely(NULL, conn, smb_fname_cwd, wcard, attr);
if (dir_hnd != NULL) {
talloc_set_destructor(dir_hnd, smb_Dir_destructor);
}
out:
vfs_ChDir(conn, saved_dir_fname);
@ -442,7 +447,13 @@ NTSTATUS dptr_create(connection_struct *conn,
smb_dname_cp,
wcard,
attr);
if (dir_hnd != NULL) {
talloc_set_destructor(dir_hnd,
smb_Dir_destructor);
}
}
TALLOC_FREE(smb_dname_cp);
}
@ -1559,8 +1570,6 @@ static struct smb_Dir *OpenDir_internal(TALLOC_CTX *mem_ctx,
dirp->name_cache_size = lp_directory_name_cache_size(SNUM(conn));
}
talloc_set_destructor(dirp, smb_Dir_destructor);
return dirp;
fail:
@ -1568,9 +1577,36 @@ static struct smb_Dir *OpenDir_internal(TALLOC_CTX *mem_ctx,
return NULL;
}
/****************************************************************************
Open a directory handle by pathname, ensuring it's under the share path.
****************************************************************************/
/**
* @brief Open a directory handle by pathname, ensuring it's under the share path.
*
* First stores the $cwd, then changes directory to the passed in pathname
* uses check_name() to ensure this is under the connection struct share path,
* then operates on a pathname of "." to ensure we're in the same place.
*
* The returned struct smb_Dir * should have a talloc destrctor added to
* ensure that when the struct is freed the internal POSIX DIR * pointer
* is closed.
*
* @code
*
* static int sample_smb_Dir_destructor(struct smb_Dir *dirp)
* {
* SMB_VFS_CLOSEDIR(dirp->conn,dirp->dir);
* }
* ..
* struct smb_Dir *dir_hnd = open_dir_safely(mem_ctx,
* conn,
* smb_dname,
* mask,
* attr);
* if (dir_hnd == NULL) {
* return NULL;
* }
* talloc_set_destructor(dir_hnd, smb_Dir_destructor);
* ..
* @endcode
*/
static struct smb_Dir *open_dir_safely(TALLOC_CTX *ctx,
connection_struct *conn,
@ -1627,6 +1663,7 @@ static struct smb_Dir *open_dir_safely(TALLOC_CTX *ctx,
dir_hnd->dir_smb_fname = cp_smb_filename(dir_hnd, smb_dname);
if (!dir_hnd->dir_smb_fname) {
TALLOC_FREE(dir_hnd);
SMB_VFS_CLOSEDIR(conn, dir_hnd->dir);
errno = ENOMEM;
}
@ -1642,11 +1679,16 @@ struct smb_Dir *OpenDir(TALLOC_CTX *mem_ctx, connection_struct *conn,
const char *mask,
uint32_t attr)
{
return open_dir_safely(mem_ctx,
struct smb_Dir *dir_hnd = open_dir_safely(mem_ctx,
conn,
smb_dname,
mask,
attr);
if (dir_hnd == NULL) {
return NULL;
}
talloc_set_destructor(dir_hnd, smb_Dir_destructor);
return dir_hnd;
}
/*******************************************************************
@ -1708,11 +1750,15 @@ static struct smb_Dir *OpenDir_fsp(TALLOC_CTX *mem_ctx, connection_struct *conn,
if (dirp->dir == NULL) {
/* FDOPENDIR is not supported. Use OPENDIR instead. */
TALLOC_FREE(dirp);
return open_dir_safely(mem_ctx,
dirp = open_dir_safely(mem_ctx,
conn,
fsp->fsp_name,
mask,
attr);
if (dirp == NULL) {
errno = ENOMEM;
goto fail;
}
}
talloc_set_destructor(dirp, smb_Dir_destructor);