On Monday, January 15, 2018 9:52:07 AM EST Joshua Ammons wrote:
 Hello All,
 
 Just thought I'd give this one more shot to see if anyone had any comments
 on my prior message (see below)?  Any input you have would be greatly
 appreciated.  I won't bother the group any more on this topic. 
Not sure if you noticed, but the audit system ships with a PCI set of rules.
# rpm -ql audit | grep pci
/usr/share/doc/audit/rules/30-pci-dss-v31.rules
 I was wondering if anyone had any experience putting together an
auditd
 configuration to meet PCI DSS 10.2.x requirements?  Below are the
 requirements and my thoughts for each one...if anyone has anything that
 they have done I'd love to hear it!
 
 10.2.2    All actions taken by any individual with root or administrative
 privileges
 
 *         Enable the pam_tty_audit.so shared library in
 /etc/pam.d/[su/sudo/sudo-i/su-l] files.
 
 o   USER_TTY event type will contain all commands from privileged user.
 
 *         Add following lines to /etc/audit/rules.d/audit.rules file:
 
 o   # Audit all actions by any individual with root or administrative
 privileges
 
 o   -a exit,always -F arch=b64 -F euid=0 -S execve -k root-commands
 
 o   -a exit,always -F arch=b32 -F euid=0 -S execve -k root-commands 
The above is best done by TTY auditing.
 
 ?  EXECVE event type will contain all commands from user with
elevated
 privileges.
 
 ?  Question: with the pam_tty_audit.so enabled, and those commands being
 logged to USER_TTY events...is this rule needed also?  
No. And you would want to add -F auid >= 1000  -F auid != -1 if you were 
keeping it.
 10.2.3    Access to all audit trails
 *         I'm not sure the best route to cover this one.  If I add a rule
 to watch /var/log/* for 'wa' actions, those logs are constantly being
 written to so that would be too noisy I believe. Does anyone know how I
 would form a rule that would fire when a file within /var/log is accessed
 directly by a user?  Also, if the user makes any manual changes, such as
 deleting a file or modifying its contents?  
Its not too noisy. Check the rules for this in the pci file. It picks up 
everything.
 10.2.4    Invalid logical access attempts
 
 *         Based on my understanding, this wouldn't really be covered by
 auditd, but by the standard authpriv facility.  Anybody configure anything
 in auditd to cover this requirement?  
pam probably covers this.
 10.2.5    Use of and changes to identification and authentication
 mechanisms-including but not limited to creation of new accounts and
 elevation of privileges-and all changes, additions, or deletions to
 accounts with root or administrative privileges 
Put a watch on passwd & group and shadow-utils does the rest.
 
 *         CRED_ACQ (sudo) and USER_AUTH (su) events should contain
when a
 user sudo's or su's to privileged account.  My understanding is that these
 would not require any extra rules to be written.  However, I'm not quite
 sure how to handle the requirements to log creation of new accounts, and
 all changes, or deletions to accounts with root/admin privileges...any
 ideas? 
Shadow utils covers this.
 10.2.6.   Initialization, stopping, or pausing of the audit logs
 
 *         Auditd:
 
 o   DAEMON_END events would indicate auditd was stopped.
 
 o   DAEMON_START and SERVICE_START events would indicate when auditd
 initialized.
 
 o   Anything else anybody would add here?
 
 *         Rsyslog:
 
 o   SERVICE_START event (unit=rsyslog) when rsyslog is initialized
 
 o   SERVICE_STOP event (unit=rsyslog) when rsyslog is stopped
 
 o   Anything else anybody would add here?
 10.2.7    Creation and deletion of system- level objects
 
 *         -w [DIRECTORY] -p wa rules for the directories below:
 
 o   /bin
 
 o   /sbin
 
 o   /usr/bin
 
 o   /usr/sbin
 
 o   /var/lib
 
 o   /usr/lib
 
 o   /usr/libexec
 
 o   /lib64
 
 o   /usr/lib64
 
 ?  Would the above cover this requirement?  Any other suggestions here? 
This will probably make you very unhappy when you do yum update. But you can 
add those rules.
-Steve