From: Jeremy Allison Date: Thu, 8 Aug 2019 22:30:54 +0000 (-0700) Subject: s3: VFS: vfs_audit. Implement renameat(). X-Git-Tag: tdb-1.4.2~99 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=365b81238e261bae2b4f4ffe968a11cb3c0ff50a;p=thirdparty%2Fsamba.git s3: VFS: vfs_audit. Implement renameat(). Currently identical to rename(). Signed-off-by: Jeremy Allison Reviewed-by: Ralph Boehme --- diff --git a/source3/modules/vfs_audit.c b/source3/modules/vfs_audit.c index 91610377c1c..81bb43ec27a 100644 --- a/source3/modules/vfs_audit.c +++ b/source3/modules/vfs_audit.c @@ -273,6 +273,30 @@ static int audit_rename(vfs_handle_struct *handle, return result; } +static int audit_renameat(vfs_handle_struct *handle, + files_struct *srcfsp, + const struct smb_filename *smb_fname_src, + files_struct *dstfsp, + const struct smb_filename *smb_fname_dst) +{ + int result; + + result = SMB_VFS_NEXT_RENAMEAT(handle, + srcfsp, + smb_fname_src, + dstfsp, + smb_fname_dst); + + syslog(audit_syslog_priority(handle), "renameat %s -> %s %s%s\n", + smb_fname_src->base_name, + smb_fname_dst->base_name, + (result < 0) ? "failed: " : "", + (result < 0) ? strerror(errno) : ""); + + return result; +} + + static int audit_unlink(vfs_handle_struct *handle, const struct smb_filename *smb_fname) { @@ -327,6 +351,7 @@ static struct vfs_fn_pointers vfs_audit_fns = { .open_fn = audit_open, .close_fn = audit_close, .rename_fn = audit_rename, + .renameat_fn = audit_renameat, .unlink_fn = audit_unlink, .chmod_fn = audit_chmod, .fchmod_fn = audit_fchmod,