/* * Copyright (c) 2009-2010 Todd C. Miller * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ #include #include #include #ifdef STDC_HEADERS # include # include #else # ifdef HAVE_STDLIB_H # include # endif #endif /* STDC_HEADERS */ #include #include "missing.h" #include "logging.h" #include "sudo_debug.h" #ifdef HAVE_BSM_AUDIT # include "bsm_audit.h" #endif #ifdef HAVE_LINUX_AUDIT # include "linux_audit.h" #endif void audit_success(char *exec_args[]) { debug_decl(audit_success, SUDO_DEBUG_AUDIT) if (exec_args != NULL) { #ifdef HAVE_BSM_AUDIT bsm_audit_success(exec_args); #endif #ifdef HAVE_LINUX_AUDIT linux_audit_command(exec_args, 1); #endif } debug_return; } void audit_failure(char *exec_args[], char const *const fmt, ...) { va_list ap; debug_decl(audit_success, SUDO_DEBUG_AUDIT) if (exec_args != NULL) { va_start(ap, fmt); #ifdef HAVE_BSM_AUDIT bsm_audit_failure(exec_args, fmt, ap); #endif #ifdef HAVE_LINUX_AUDIT linux_audit_command(exec_args, 0); #endif va_end(ap); } debug_return; }