2014-02-28 23:27:55 +04:00
|
|
|
==========
|
2014-04-03 03:40:31 +04:00
|
|
|
Audisp-json
|
2014-02-28 23:27:55 +04:00
|
|
|
==========
|
|
|
|
|
|
|
|
.. contents:: Table of contents
|
|
|
|
|
|
|
|
This program is a plugin for Linux Audit user space programs available at <http://people.redhat.com/sgrubb/audit/>.
|
|
|
|
It uses the audisp multiplexer.
|
|
|
|
|
2014-04-27 20:57:39 +04:00
|
|
|
Audisp-json correlates messages coming from the kernel's audit (and through audisp) into a single JSON message that is
|
|
|
|
sent directly to a log server (it doesn't use syslog).
|
2014-04-03 03:40:31 +04:00
|
|
|
The JSON format used is MozDef message format.
|
2014-02-28 23:27:55 +04:00
|
|
|
|
2014-04-27 20:57:39 +04:00
|
|
|
Regular audit log messages and audisp-json error, info messages still use syslog.
|
|
|
|
|
2014-02-28 23:27:55 +04:00
|
|
|
Building
|
|
|
|
--------
|
|
|
|
|
|
|
|
Required dependencies:
|
|
|
|
- Audit (2.0+)
|
2014-03-26 22:36:08 +04:00
|
|
|
- libtool
|
2014-04-27 20:57:39 +04:00
|
|
|
- libcurl
|
2014-02-28 23:27:55 +04:00
|
|
|
|
|
|
|
For package building:
|
|
|
|
- FPM
|
|
|
|
- rpmbuild (rpm)
|
|
|
|
|
|
|
|
Build targets:
|
|
|
|
=============
|
|
|
|
They're self explanatory.
|
|
|
|
|
|
|
|
- make
|
|
|
|
- make rpm
|
|
|
|
- make deb
|
|
|
|
- make install
|
|
|
|
- make uninstall
|
|
|
|
- make clean
|
|
|
|
|
|
|
|
Deal with auditd quirks, or how to make auditd useable in prod
|
|
|
|
--------------------------------------------------------------
|
|
|
|
|
|
|
|
We're assuming you're logging auditd stuff to LOCAL5 here. Replace <SYSLOG_SERVER_IP_HERE> by your syslogger.
|
|
|
|
Due to the nature/sensitivity of the logs, using TLS as transport is highly recommended.
|
|
|
|
|
2014-03-26 22:36:08 +04:00
|
|
|
These examples filter out messages that may kill your log if auditd goes down for any reason, or general
|
|
|
|
messages which you may want to forward but to keep in their own faciilty, or simply not log to disk, for
|
|
|
|
useability reasons.
|
|
|
|
|
2014-02-28 23:27:55 +04:00
|
|
|
Example for rsyslog
|
|
|
|
===================
|
|
|
|
|
|
|
|
::
|
|
|
|
|
|
|
|
#Drop native audit messages from the kernel (may happen is auditd dies, and may kill the system otherwise)
|
|
|
|
:msg, regex, "type=[0-9]* audit" ~
|
|
|
|
#Sent audit rate limit errors directly to the remote syslog server
|
|
|
|
:msg, contains, "rate limit exceeded" @<SYSLOG_SERVER_IP_HERE>
|
|
|
|
:msg, contains, "audit_lost=" @<SYSLOG_SERVER_IP_HERE>
|
|
|
|
#Drop audit sid msg (work-around until RH fixes the kernel - should be fixed in RHEL7 and recent RHEL6)
|
|
|
|
:msg, contains, "error converting sid to string" ~
|
|
|
|
|
|
|
|
#Don't log auditd messages to disk, we're logging way too much stuff for that
|
|
|
|
*.info;local5.none /var/log/messages
|
|
|
|
#Log remotely instead
|
|
|
|
local5.* @<SYSLOG_SERVER_IP_HERE>
|
|
|
|
|
|
|
|
Example for syslog-ng
|
|
|
|
=====================
|
|
|
|
|
|
|
|
::
|
|
|
|
|
|
|
|
source s_syslog { unix-dgram("/dev/log"); };
|
2014-03-20 03:22:19 +04:00
|
|
|
filter f_auditd { message("type=[0-9]* audit") and message("rate limit exceeded") and message("audit_lost=") and facility(local5); };
|
2014-02-28 23:27:55 +04:00
|
|
|
destination d_logserver { udp("<SYSLOG_SERVER_IP_HERE>" port(514)); };
|
|
|
|
log{ source(s_syslog); filter(f_auditd); destination(d_logserver); };
|
2014-03-20 03:22:19 +04:00
|
|
|
# If you want to "not log" auditd messages, negate the same filter to your other log items
|
2014-04-27 20:57:39 +04:00
|
|
|
|
2014-03-26 22:36:08 +04:00
|
|
|
Message handling
|
|
|
|
----------------
|
|
|
|
|
2014-04-03 03:40:31 +04:00
|
|
|
Syscalls are interpreted by audisp-json and transformed into a MozDef JSON message.
|
2014-03-26 22:36:08 +04:00
|
|
|
This means, for example, all execve() and related calls will be aggregated into a message of type EXECVE.
|
|
|
|
|
2014-04-27 20:57:39 +04:00
|
|
|
.. note: MozDef messages are not sent to syslog. They're sent to MozDef directly.
|
|
|
|
|
2014-03-26 22:36:08 +04:00
|
|
|
Supported messages are listed in the document messages_format.rst
|
2014-04-30 03:23:25 +04:00
|
|
|
|
|
|
|
Configuration file
|
|
|
|
==================
|
|
|
|
|
|
|
|
The audisp-json.conf file has 3 options:
|
|
|
|
|
|
|
|
:mozdef_url: Any server supporting JSON MozDef messages
|
|
|
|
:ssl_verify: Yes or no. Only use no for testing purposes.
|
|
|
|
:curl_verbose: Enables curl verbose mode for debugging. start audisp-json in the foreground to see messages.
|