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

smbd: prepare for replacing SMB_VFS_READLINKAT() with SMB_VFS_STATX() in the future

Add a large comment inside process_symlink_open() explaining why we need to call
SMB_VFS_READLINKAT().

As we don't make use of the returned name and just rely on SMB_VFS_REALPATH()
doing its job, remove target_fname

Signed-off-by: Ralph Boehme <slow@samba.org>
Reviewed-by: Jeremy Allison <jra@samba.org>
This commit is contained in:
Ralph Boehme 2020-04-09 15:42:59 +02:00
parent 60c47a5d13
commit 15303ee19b

View File

@ -481,7 +481,6 @@ static int process_symlink_open(struct connection_struct *conn,
{ {
int fd = -1; int fd = -1;
char *link_target = NULL; char *link_target = NULL;
struct smb_filename target_fname = {0};
int link_len = -1; int link_len = -1;
struct smb_filename *oldwd_fname = NULL; struct smb_filename *oldwd_fname = NULL;
size_t rootdir_len = 0; size_t rootdir_len = 0;
@ -506,7 +505,19 @@ static int process_symlink_open(struct connection_struct *conn,
goto out; goto out;
} }
/* Read the link target. */ /*
* Read the link target. We do this just to verify that smb_fname indeed
* points at a symbolic link and return the SMB_VFS_READLINKAT() errno
* and failure in case smb_fname is NOT a symlink.
*
* The caller needs this piece of information to distinguish two cases
* where open() fails with errno=ENOTDIR, cf the comment in
* non_widelink_open().
*
* We rely on SMB_VFS_REALPATH() to resolve the path including the
* symlink. Once we have SMB_VFS_STATX() or something similar in our VFS
* we may want to use that instead of SMB_VFS_READLINKAT().
*/
link_len = SMB_VFS_READLINKAT(conn, link_len = SMB_VFS_READLINKAT(conn,
conn->cwd_fsp, conn->cwd_fsp,
smb_fname, smb_fname,
@ -516,15 +527,8 @@ static int process_symlink_open(struct connection_struct *conn,
goto out; goto out;
} }
/* Ensure it's at least null terminated. */
link_target[link_len] = '\0';
target_fname = (struct smb_filename) {
.base_name = link_target,
.twrp = smb_fname->twrp,
};
/* Convert to an absolute path. */ /* Convert to an absolute path. */
resolved_fname = SMB_VFS_REALPATH(conn, talloc_tos(), &target_fname); resolved_fname = SMB_VFS_REALPATH(conn, talloc_tos(), smb_fname);
if (resolved_fname == NULL) { if (resolved_fname == NULL) {
goto out; goto out;
} }