vfs_audit: support real dirfsps in audit_mkdirat()
authorRalph Boehme <slow@samba.org>
Mon, 14 Dec 2020 14:42:23 +0000 (15:42 +0100)
committerJeremy Allison <jra@samba.org>
Thu, 17 Dec 2020 18:56:29 +0000 (18:56 +0000)
Signed-off-by: Ralph Boehme <slow@samba.org>
Reviewed-by: Jeremy Allison <jra@samba.org>
source3/modules/vfs_audit.c

index bf0e043f505b4797da194ed56c947843682ec10a..f62591f7be0bb17f43aaadbce9648d7cd276a2f1 100644 (file)
@@ -182,18 +182,28 @@ static int audit_mkdirat(vfs_handle_struct *handle,
                const struct smb_filename *smb_fname,
                mode_t mode)
 {
+       struct smb_filename *full_fname = NULL;
        int result;
 
+       full_fname = full_path_from_dirfsp_atname(talloc_tos(),
+                                                 dirfsp,
+                                                 smb_fname);
+       if (full_fname == NULL) {
+               errno = ENOMEM;
+               return -1;
+       }
+
        result = SMB_VFS_NEXT_MKDIRAT(handle,
                        dirfsp,
                        smb_fname,
                        mode);
 
        syslog(audit_syslog_priority(handle), "mkdirat %s %s%s\n",
-              smb_fname->base_name,
+              full_fname->base_name,
               (result < 0) ? "failed: " : "",
               (result < 0) ? strerror(errno) : "");
 
+       TALLOC_FREE(full_fname);
        return result;
 }