mirror of
https://github.com/samba-team/samba.git
synced 2024-12-22 13:34:15 +03:00
s3/utils: smbcacls failed to detect DIRECTORIES using SMB2 (windows only)
uint16_t get_fileinfo(...) returns file attributes, this function called cli_qfileinfo_basic(cli, fnum, &mode, NULL, NULL, NULL, NULL, NULL, NULL); which was failing with NT_STATUS_ACCESS_DENIED errors when fnum above was obtained via (when using protocol > SMB). Note: This only seems to be an issue when run against a windows server, with smbd SMB1 & SMB2 work fine. status = cli_ntcreate(cli, filename, 0, CREATE_ACCESS_READ, 0, FILE_SHARE_READ|FILE_SHARE_WRITE, FILE_OPEN, 0x0, 0x0, &fnum, NULL); The failing cli_qfileinfo_basic call above is unnecessary as we can already obtain the required information from the cli_ntcreate call Signed-off-by: Noel Power <noel.power@suse.com> Reviewed-by: Jeremy Allison <jra@samba.org> Reviewed-by: David Disseldorp <ddiss@samba.org>
This commit is contained in:
parent
7313e7c10d
commit
c57dcafb15
@ -229,30 +229,22 @@ get fileinfo for filename
|
||||
static uint16_t get_fileinfo(struct cli_state *cli, const char *filename)
|
||||
{
|
||||
uint16_t fnum = (uint16_t)-1;
|
||||
uint16_t mode = 0;
|
||||
NTSTATUS status;
|
||||
struct smb_create_returns cr = {0};
|
||||
|
||||
/* The desired access below is the only one I could find that works
|
||||
with NT4, W2KP and Samba */
|
||||
|
||||
status = cli_ntcreate(cli, filename, 0, CREATE_ACCESS_READ,
|
||||
0, FILE_SHARE_READ|FILE_SHARE_WRITE,
|
||||
FILE_OPEN, 0x0, 0x0, &fnum, NULL);
|
||||
FILE_OPEN, 0x0, 0x0, &fnum, &cr);
|
||||
if (!NT_STATUS_IS_OK(status)) {
|
||||
printf("Failed to open %s: %s\n", filename, nt_errstr(status));
|
||||
return 0;
|
||||
}
|
||||
|
||||
status = cli_qfileinfo_basic(cli, fnum, &mode, NULL, NULL, NULL,
|
||||
NULL, NULL, NULL);
|
||||
if (!NT_STATUS_IS_OK(status)) {
|
||||
printf("Failed to file info %s: %s\n", filename,
|
||||
nt_errstr(status));
|
||||
}
|
||||
|
||||
cli_close(cli, fnum);
|
||||
|
||||
return mode;
|
||||
return cr.file_attributes;
|
||||
}
|
||||
|
||||
/*****************************************************
|
||||
|
Loading…
Reference in New Issue
Block a user