Annotation of embedaddon/sudo/plugins/sudoers/audit.c, revision 1.1.1.5.2.1
1.1 misho 1: /*
1.1.1.3 misho 2: * Copyright (c) 2009-2012 Todd C. Miller <Todd.Miller@courtesan.com>
1.1 misho 3: *
4: * Permission to use, copy, modify, and distribute this software for any
5: * purpose with or without fee is hereby granted, provided that the above
6: * copyright notice and this permission notice appear in all copies.
7: *
8: * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9: * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10: * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
11: * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12: * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
13: * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
14: * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
15: */
16:
17: #include <config.h>
18:
19: #include <sys/types.h>
20: #include <stdio.h>
21: #ifdef STDC_HEADERS
22: # include <stdlib.h>
23: # include <stddef.h>
24: #else
25: # ifdef HAVE_STDLIB_H
26: # include <stdlib.h>
27: # endif
28: #endif /* STDC_HEADERS */
1.1.1.3 misho 29: #ifdef HAVE_STDBOOL_H
30: # include <stdbool.h>
31: #else
32: # include "compat/stdbool.h"
33: #endif /* HAVE_STDBOOL_H */
1.1 misho 34: #include <stdarg.h>
35:
1.1.1.5 misho 36: #define DEFAULT_TEXT_DOMAIN "sudoers"
37: #include "gettext.h" /* must be included before missing.h */
38:
1.1 misho 39: #include "missing.h"
40: #include "logging.h"
1.1.1.2 misho 41: #include "sudo_debug.h"
1.1 misho 42:
43: #ifdef HAVE_BSM_AUDIT
44: # include "bsm_audit.h"
1.1.1.5.2.1! misho 45: # include "gettext.h"
1.1 misho 46: #endif
47: #ifdef HAVE_LINUX_AUDIT
48: # include "linux_audit.h"
49: #endif
50:
51: void
52: audit_success(char *exec_args[])
53: {
1.1.1.2 misho 54: debug_decl(audit_success, SUDO_DEBUG_AUDIT)
1.1 misho 55:
1.1.1.2 misho 56: if (exec_args != NULL) {
1.1 misho 57: #ifdef HAVE_BSM_AUDIT
1.1.1.2 misho 58: bsm_audit_success(exec_args);
1.1 misho 59: #endif
60: #ifdef HAVE_LINUX_AUDIT
1.1.1.2 misho 61: linux_audit_command(exec_args, 1);
1.1 misho 62: #endif
1.1.1.2 misho 63: }
64:
65: debug_return;
1.1 misho 66: }
67:
68: void
69: audit_failure(char *exec_args[], char const *const fmt, ...)
70: {
71: va_list ap;
1.1.1.3 misho 72: int oldlocale;
1.1.1.2 misho 73: debug_decl(audit_success, SUDO_DEBUG_AUDIT)
1.1 misho 74:
1.1.1.3 misho 75: /* Audit error messages should be in the sudoers locale. */
76: sudoers_setlocale(SUDOERS_LOCALE_SUDOERS, &oldlocale);
77:
1.1.1.2 misho 78: if (exec_args != NULL) {
79: va_start(ap, fmt);
1.1 misho 80: #ifdef HAVE_BSM_AUDIT
1.1.1.3 misho 81: bsm_audit_failure(exec_args, _(fmt), ap);
1.1 misho 82: #endif
83: #ifdef HAVE_LINUX_AUDIT
1.1.1.2 misho 84: linux_audit_command(exec_args, 0);
1.1 misho 85: #endif
1.1.1.2 misho 86: va_end(ap);
87: }
88:
1.1.1.3 misho 89: sudoers_setlocale(oldlocale, NULL);
90:
1.1.1.2 misho 91: debug_return;
1.1 misho 92: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>