git.samba.org
/
metze
/
samba
/
wip.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
s3 file_access: Convert some more functions over to use smb_filneame
[metze/samba/wip.git]
/
source3
/
smbd
/
posix_acls.c
diff --git
a/source3/smbd/posix_acls.c
b/source3/smbd/posix_acls.c
index 437112c751d5cc6916c0e19e0f7e4162326db55b..627ca2e171f2288ba404fa1124222fcde1385d5d 100644
(file)
--- a/
source3/smbd/posix_acls.c
+++ b/
source3/smbd/posix_acls.c
@@
-2550,6
+2550,9
@@
static bool acl_group_override(connection_struct *conn,
const SMB_STRUCT_STAT *psbuf,
const char *fname)
{
const SMB_STRUCT_STAT *psbuf,
const char *fname)
{
+ struct smb_filename *smb_fname = NULL;
+ NTSTATUS status;
+
if ((errno != EPERM) && (errno != EACCES)) {
return false;
}
if ((errno != EPERM) && (errno != EACCES)) {
return false;
}
@@
-2560,11
+2563,20
@@
static bool acl_group_override(connection_struct *conn,
return true;
}
return true;
}
+ status = create_synthetic_smb_fname_split(talloc_tos(), fname, psbuf,
+ &smb_fname);
+
+ if (!NT_STATUS_IS_OK(status)) {
+ return false;
+ }
+
/* user has writeable permission */
if (lp_dos_filemode(SNUM(conn)) &&
/* user has writeable permission */
if (lp_dos_filemode(SNUM(conn)) &&
- can_write_to_file(conn, fname, psbuf)) {
+ can_write_to_file(conn, smb_fname)) {
+ TALLOC_FREE(smb_fname);
return true;
}
return true;
}
+ TALLOC_FREE(smb_fname);
return false;
}
return false;
}