mirror of
https://github.com/samba-team/samba.git
synced 2025-01-10 01:18:15 +03:00
smbd: Fix the turning an absolute symlink into a relative one
If dirfsp is the share root, we end up with a "/." at the end of subdir_path. subdir_of() does not cover that case. fsp_fullbasepath() takes care of that case and also avoids a talloc. Signed-off-by: Volker Lendecke <vl@samba.org> Reviewed-by: Ralph Boehme <slow@samba.org>
This commit is contained in:
parent
259517d7ae
commit
0d8b71f0b6
@ -808,18 +808,13 @@ NTSTATUS read_symlink_reparse(TALLOC_CTX *mem_ctx,
|
||||
}
|
||||
|
||||
if (lnk->substitute_name[0] == '/') {
|
||||
char *subdir_path = NULL;
|
||||
size_t len = fsp_fullbasepath(dirfsp, NULL, 0);
|
||||
char subdir_path[len + 1];
|
||||
char *abs_target_canon = NULL;
|
||||
const char *relative = NULL;
|
||||
bool in_share;
|
||||
|
||||
subdir_path = talloc_asprintf(talloc_tos(),
|
||||
"%s/%s",
|
||||
dirfsp->conn->connectpath,
|
||||
dirfsp->fsp_name->base_name);
|
||||
if (subdir_path == NULL) {
|
||||
goto nomem;
|
||||
}
|
||||
fsp_fullbasepath(dirfsp, subdir_path, sizeof(subdir_path));
|
||||
|
||||
abs_target_canon = canonicalize_absolute_path(
|
||||
talloc_tos(), lnk->substitute_name);
|
||||
@ -828,7 +823,7 @@ NTSTATUS read_symlink_reparse(TALLOC_CTX *mem_ctx,
|
||||
}
|
||||
|
||||
in_share = subdir_of(subdir_path,
|
||||
strlen(subdir_path),
|
||||
len,
|
||||
abs_target_canon,
|
||||
&relative);
|
||||
if (in_share) {
|
||||
|
Loading…
Reference in New Issue
Block a user