1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-25 06:04:04 +03:00

r13028: Fix for #3419 - vfs_full_audit *never* worked

correctly. Static variables were used !
Jeremy.
(This used to be commit 2ab5aeca895476869f0b50e513a77c9f2558fc56)
This commit is contained in:
Jeremy Allison 2006-01-19 00:34:48 +00:00 committed by Gerald (Jerry) Carter
parent 543ff192b3
commit cd8f41c327

View File

@ -35,6 +35,9 @@
* full_audit:success = open opendir
* full_audit:failure = all
*
* vfs op can be "all" which means log all operations.
* vfs op can be "none" which means no logging.
*
* This leads to syslog entries of the form:
* smbd_audit: nobody|192.168.234.1|opendir|ok|.
* smbd_audit: nobody|192.168.234.1|open|fail (File not found)|r|x.txt
@ -61,6 +64,11 @@ extern struct current_user current_user;
static int vfs_full_audit_debug_level = DBGC_VFS;
struct vfs_full_audit_private_data {
struct bitmap *success_ops;
struct bitmap *failure_ops;
};
#undef DBGC_CLASS
#define DBGC_CLASS vfs_full_audit_debug_level
@ -662,24 +670,33 @@ static char *audit_prefix(connection_struct *conn)
return prefix;
}
static struct bitmap *success_ops = NULL;
static BOOL log_success(vfs_op_type op)
static BOOL log_success(vfs_handle_struct *handle, vfs_op_type op)
{
if (success_ops == NULL)
return True;
struct vfs_full_audit_private_data *pd = NULL;
return bitmap_query(success_ops, op);
SMB_VFS_HANDLE_GET_DATA(handle, pd,
struct vfs_full_audit_private_data,
return True);
if (pd->success_ops == NULL) {
return True;
}
return bitmap_query(pd->success_ops, op);
}
static struct bitmap *failure_ops = NULL;
static BOOL log_failure(vfs_op_type op)
static BOOL log_failure(vfs_handle_struct *handle, vfs_op_type op)
{
if (failure_ops == NULL)
struct vfs_full_audit_private_data *pd = NULL;
SMB_VFS_HANDLE_GET_DATA(handle, pd,
struct vfs_full_audit_private_data,
return True);
if (pd->failure_ops == NULL)
return True;
return bitmap_query(failure_ops, op);
return bitmap_query(pd->failure_ops, op);
}
static void init_bitmap(struct bitmap **bm, const char **ops)
@ -706,6 +723,10 @@ static void init_bitmap(struct bitmap **bm, const char **ops)
break;
}
if (strequal(*ops, "none")) {
break;
}
for (i=0; i<SMB_VFS_OP_LAST; i++) {
if (vfs_op_names[i].name == NULL) {
smb_panic("vfs_full_audit.c: name table not "
@ -747,10 +768,10 @@ static void do_log(vfs_op_type op, BOOL success, vfs_handle_struct *handle,
pstring op_msg;
va_list ap;
if (success && (!log_success(op)))
if (success && (!log_success(handle, op)))
return;
if (!success && (!log_failure(op)))
if (!success && (!log_failure(handle, op)))
return;
if (success)
@ -768,6 +789,22 @@ static void do_log(vfs_op_type op, BOOL success, vfs_handle_struct *handle,
return;
}
/* Free function for the private data. */
static void free_private_data(void **p_data)
{
struct vfs_full_audit_private_data *pd = *(struct vfs_full_audit_private_data **)p_data;
if (pd->success_ops) {
bitmap_free(pd->success_ops);
}
if (pd->failure_ops) {
bitmap_free(pd->failure_ops);
}
SAFE_FREE(pd);
*p_data = NULL;
}
/* Implementation of vfs_ops. Pass everything on to the default
operation but log event first. */
@ -775,18 +812,29 @@ static int smb_full_audit_connect(vfs_handle_struct *handle, connection_struct *
const char *svc, const char *user)
{
int result;
struct vfs_full_audit_private_data *pd = NULL;
const char *none[] = { NULL };
const char *all [] = { "all" };
pd = SMB_MALLOC_P(struct vfs_full_audit_private_data);
if (!pd) {
return -1;
}
ZERO_STRUCTP(pd);
openlog("smbd_audit", 0, audit_syslog_facility(handle));
init_bitmap(&success_ops,
init_bitmap(&pd->success_ops,
lp_parm_string_list(SNUM(conn), "full_audit", "success",
none));
init_bitmap(&failure_ops,
init_bitmap(&pd->failure_ops,
lp_parm_string_list(SNUM(conn), "full_audit", "failure",
all));
/* Store the private data. */
SMB_VFS_HANDLE_SET_DATA(handle, pd, free_private_data,
struct vfs_full_audit_private_data, return -1);
result = SMB_VFS_NEXT_CONNECT(handle, conn, svc, user);
do_log(SMB_VFS_OP_CONNECT, True, handle,
@ -803,11 +851,8 @@ static void smb_full_audit_disconnect(vfs_handle_struct *handle,
do_log(SMB_VFS_OP_DISCONNECT, True, handle,
"%s", lp_servicename(SNUM(conn)));
bitmap_free(success_ops);
success_ops = NULL;
bitmap_free(failure_ops);
failure_ops = NULL;
/* The bitmaps will be disconnected when the private
data is deleted. */
return;
}
@ -2003,4 +2048,3 @@ NTSTATUS vfs_full_audit_init(void)
return ret;
}