Merge tag 'debian/1.8.5p2-1' into squeeze
[debian/sudo] / plugins / sudoers / audit.c
diff --git a/plugins/sudoers/audit.c b/plugins/sudoers/audit.c
new file mode 100644 (file)
index 0000000..d2dcca3
--- /dev/null
@@ -0,0 +1,77 @@
+/*
+ * Copyright (c) 2009-2010 Todd C. Miller <Todd.Miller@courtesan.com>
+ *
+ * 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 <config.h>
+
+#include <sys/types.h>
+#include <stdio.h>
+#ifdef STDC_HEADERS
+# include <stdlib.h>
+# include <stddef.h>
+#else
+# ifdef HAVE_STDLIB_H
+#  include <stdlib.h>
+# endif
+#endif /* STDC_HEADERS */
+#include <stdarg.h>
+
+#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;
+}