Este contenido no está disponible en el idioma seleccionado.
Chapter 11. Auditing the system
Although Audit does not provide additional security to your system, you can use it to discover violations of security policies on your system. Then, you can prevent future such violations by configuring additional security measures such as SELinux.
11.1. Linux Audit
The Linux Audit system provides a way to track security-relevant information about your system. Based on pre-configured rules, Audit generates log entries to record as much information about the events that are happening on your system as possible. This information is crucial for mission-critical environments to determine the violator of the security policy and the actions they performed.
The following list summarizes some of the information that Audit is capable of recording in its log files:
- Date and time, type, and outcome of an event
- Sensitivity labels of subjects and objects
- Association of an event with the identity of the user who triggered the event
- All modifications to Audit configuration and attempts to access Audit log files
- All uses of authentication mechanisms, such as SSH, Kerberos, and others
- 
						Changes to any trusted database, such as /etc/passwd
- Attempts to import or export information into or from the system
- Include or exclude events based on user identity, subject and object labels, and other attributes
The use of the Audit system is also a requirement for a number of security-related certifications. Audit is designed to meet or exceed the requirements of the following certifications or compliance guides:
- Controlled Access Protection Profile (CAPP)
- Labeled Security Protection Profile (LSPP)
- Rule Set Base Access Control (RSBAC)
- National Industrial Security Program Operating Manual (NISPOM)
- Federal Information Security Management Act (FISMA)
- Payment Card Industry - Data Security Standard (PCI-DSS)
- Security Technical Implementation Guides (STIG)
Audit has also been evaluated by National Information Assurance Partnership (NIAP) and Best Security Industries (BSI).
Use Cases
- Watching file access
- Audit can track whether a file or a directory has been accessed, modified, executed, or the file’s attributes have been changed. This is useful, for example, to detect access to important files and have an Audit trail available in case one of these files is corrupted.
- Monitoring system calls
- 
							Audit can be configured to generate a log entry every time a particular system call is used. This can be used, for example, to track changes to the system time by monitoring the settimeofday,clock_adjtime, and other time-related system calls.
- Recording commands run by a user
- 
							Audit can track whether a file has been executed, so rules can be defined to record every execution of a particular command. For example, a rule can be defined for every executable in the /bindirectory. The resulting log entries can then be searched by user ID to generate an audit trail of executed commands per user.
- Recording execution of system pathnames
- Aside from watching file access which translates a path to an inode at rule invocation, Audit can now watch the execution of a path even if it does not exist at rule invocation, or if the file is replaced after rule invocation. This allows rules to continue to work after upgrading a program executable or before it is even installed.
- Recording security events
- 
							The pam_faillockauthentication module is capable of recording failed login attempts. Audit can be set up to record failed login attempts as well and provides additional information about the user who attempted to log in.
- Searching for events
- 
							Audit provides the ausearchutility, which can be used to filter the log entries and provide a complete audit trail based on several conditions.
- Running summary reports
- 
							The aureportutility can be used to generate, among other things, daily reports of recorded events. A system administrator can then analyze these reports and investigate suspicious activity further.
- Monitoring network access
- 
							The nftables,iptables, andebtablesutilities can be configured to trigger Audit events, allowing system administrators to monitor network access.
System performance may be affected depending on the amount of information that is collected by Audit.
11.2. Audit system architecture
The Audit system consists of two main parts: the user-space applications and utilities, and the kernel-side system call processing. The kernel component receives system calls from user-space applications and filters them through one of the following filters: user, task, fstype, or exit.
After a system call passes the exclude filter, it is sent through one of the aforementioned filters, which, based on the Audit rule configuration, sends it to the Audit daemon for further processing.
The user-space Audit daemon collects the information from the kernel and creates entries in a log file. Other Audit user-space utilities interact with the Audit daemon, the kernel Audit component, or the Audit log files:
- 
						The auditctlAudit control utility interacts with the kernel Audit component to manage rules and to control many settings and parameters of the event generation process.
- 
						The remaining Audit utilities take the contents of the Audit log files as input and generate output based on user’s requirements. For example, the aureportutility generates a report of all recorded events.
				In RHEL 9, the Audit dispatcher daemon (audisp) functionality is integrated in the Audit daemon (auditd). Configuration files of plugins for the interaction of real-time analytical programs with Audit events are located in the /etc/audit/plugins.d/ directory by default.
			
11.3. Configuring auditd for a secure environment
				The default auditd configuration should be suitable for most environments. However, if your environment must meet strict security policies, you can change the following settings for the Audit daemon configuration in the /etc/audit/auditd.conf file:
			
- log_file
- 
							The directory that holds the Audit log files (usually /var/log/audit/) should reside on a separate mount point. This prevents other processes from consuming space in this directory and provides accurate detection of the remaining space for the Audit daemon.
- max_log_file
- 
							Specifies the maximum size of a single Audit log file, must be set to make full use of the available space on the partition that holds the Audit log files. The max_log_file`parameter specifies the maximum file size in megabytes. The value given must be numeric.
- max_log_file_action
- 
							Decides what action is taken once the limit set in max_log_fileis reached, should be set tokeep_logsto prevent Audit log files from being overwritten.
- space_left
- 
							Specifies the amount of free space left on the disk for which an action that is set in the space_left_actionparameter is triggered. Must be set to a number that gives the administrator enough time to respond and free up disk space. Thespace_leftvalue depends on the rate at which the Audit log files are generated. If the value of space_left is specified as a whole number, it is interpreted as an absolute size in megabytes (MiB). If the value is specified as a number between 1 and 99 followed by a percentage sign (for example, 5%), the Audit daemon calculates the absolute size in megabytes based on the size of the file system containinglog_file.
- space_left_action
- 
							It is recommended to set the space_left_actionparameter toemailorexecwith an appropriate notification method.
- admin_space_left
- 
							Specifies the absolute minimum amount of free space for which an action that is set in the admin_space_left_actionparameter is triggered, must be set to a value that leaves enough space to log actions performed by the administrator. The numeric value for this parameter should be lower than the number for space_left. You can also append a percent sign (for example, 1%) to the number to have the audit daemon calculate the number based on the disk partition size.
- admin_space_left_action
- 
							Should be set to singleto put the system into single-user mode and allow the administrator to free up some disk space.
- disk_full_action
- 
							Specifies an action that is triggered when no free space is available on the partition that holds the Audit log files, must be set to haltorsingle. This ensures that the system is either shut down or operating in single-user mode when Audit can no longer log events.
- disk_error_action
- 
							Specifies an action that is triggered in case an error is detected on the partition that holds the Audit log files, must be set to syslog,single, orhalt, depending on your local security policies regarding the handling of hardware malfunctions.
- flush
- 
							Should be set to incremental_async. It works in combination with thefreqparameter, which determines how many records can be sent to the disk before forcing a hard synchronization with the hard drive. Thefreqparameter should be set to100. These parameters assure that Audit event data is synchronized with the log files on the disk while keeping good performance for bursts of activity.
The remaining configuration options should be set according to your local security policy.
11.4. Starting and controlling auditd
				After auditd is configured, start the service to collect Audit information and store it in the log files. Use the following command as the root user to start auditd:
			
service auditd start
# service auditd start
				To configure auditd to start at boot time:
			
systemctl enable auditd
# systemctl enable auditd
				You can temporarily disable auditd with the # auditctl -e 0 command and re-enable it with # auditctl -e 1.
			
				You can perform other actions on auditd by using the service auditd <action> command, where <action> can be one of the following:
			
- stop
- 
							Stops auditd.
- restart
- 
							Restarts auditd.
- reloador- force-reload
- 
							Reloads the configuration of auditdfrom the/etc/audit/auditd.conffile.
- rotate
- 
							Rotates the log files in the /var/log/audit/directory.
- resume
- Resumes logging of Audit events after it has been previously suspended, for example, when there is not enough free space on the disk partition that holds the Audit log files.
- condrestartor- try-restart
- 
							Restarts auditdonly if it is already running.
- status
- 
							Displays the running status of auditd.
					The service command is the only way to correctly interact with the auditd daemon. You need to use the service command so that the auid value is properly recorded. You can use the systemctl command only for two actions: enable and status.
				
11.5. Understanding Audit log files
				By default, the Audit system stores log entries in the /var/log/audit/audit.log file; if log rotation is enabled, rotated audit.log files are stored in the same directory.
			
				Add the following Audit rule to log every attempt to read or modify the /etc/ssh/sshd_config file:
			
auditctl -w /etc/ssh/sshd_config -p warx -k sshd_config
# auditctl -w /etc/ssh/sshd_config -p warx -k sshd_config
				If the auditd daemon is running, for example, using the following command creates a new event in the Audit log file:
			
cat /etc/ssh/sshd_config
$ cat /etc/ssh/sshd_config
				This event in the audit.log file looks as follows:
			
type=SYSCALL msg=audit(1364481363.243:24287): arch=c000003e syscall=2 success=no exit=-13 a0=7fffd19c5592 a1=0 a2=7fffd19c4b50 a3=a items=1 ppid=2686 pid=3538 auid=1000 uid=1000 gid=1000 euid=1000 suid=1000 fsuid=1000 egid=1000 sgid=1000 fsgid=1000 tty=pts0 ses=1 comm="cat" exe="/bin/cat" subj=unconfined_u:unconfined_r:unconfined_t:s0-s0:c0.c1023 key="sshd_config" type=CWD msg=audit(1364481363.243:24287): cwd="/home/shadowman" type=PATH msg=audit(1364481363.243:24287): item=0 name="/etc/ssh/sshd_config" inode=409248 dev=fd:00 mode=0100600 ouid=0 ogid=0 rdev=00:00 obj=system_u:object_r:etc_t:s0 nametype=NORMAL cap_fp=none cap_fi=none cap_fe=0 cap_fver=0 type=PROCTITLE msg=audit(1364481363.243:24287) : proctitle=636174002F6574632F7373682F737368645F636F6E666967
type=SYSCALL msg=audit(1364481363.243:24287): arch=c000003e syscall=2 success=no exit=-13 a0=7fffd19c5592 a1=0 a2=7fffd19c4b50 a3=a items=1 ppid=2686 pid=3538 auid=1000 uid=1000 gid=1000 euid=1000 suid=1000 fsuid=1000 egid=1000 sgid=1000 fsgid=1000 tty=pts0 ses=1 comm="cat" exe="/bin/cat" subj=unconfined_u:unconfined_r:unconfined_t:s0-s0:c0.c1023 key="sshd_config"
type=CWD msg=audit(1364481363.243:24287):  cwd="/home/shadowman"
type=PATH msg=audit(1364481363.243:24287): item=0 name="/etc/ssh/sshd_config" inode=409248 dev=fd:00 mode=0100600 ouid=0 ogid=0 rdev=00:00 obj=system_u:object_r:etc_t:s0  nametype=NORMAL cap_fp=none cap_fi=none cap_fe=0 cap_fver=0
type=PROCTITLE msg=audit(1364481363.243:24287) : proctitle=636174002F6574632F7373682F737368645F636F6E666967
				The above event consists of four records, which share the same time stamp and serial number. Records always start with the type= keyword. Each record consists of several name=value pairs separated by a white space or a comma. A detailed analysis of the above event follows:
			
First Record
- type=SYSCALL
- 
							The typefield contains the type of the record. In this example, theSYSCALLvalue specifies that this record was triggered by a system call to the kernel.
- msg=audit(1364481363.243:24287):
- The - msgfield records:- 
									A time stamp and a unique ID of the record in the form audit(time_stamp:ID). Multiple records can share the same time stamp and ID if they were generated as part of the same Audit event. The time stamp is using the Unix time format - seconds since 00:00:00 UTC on 1 January 1970.
- 
									Various event-specific name=valuepairs provided by the kernel or user-space applications.
 
- 
									A time stamp and a unique ID of the record in the form 
- arch=c000003e
- 
							The archfield contains information about the CPU architecture of the system. The value,c000003e, is encoded in hexadecimal notation. When searching Audit records with theausearchcommand, use the-ior--interpretoption to automatically convert hexadecimal values into their human-readable equivalents. Thec000003evalue is interpreted asx86_64.
- syscall=2
- 
							The syscallfield records the type of the system call that was sent to the kernel. The value,2, can be matched with its human-readable equivalent in the/usr/include/asm/unistd_64.hfile. In this case,2is theopensystem call. Note that theausyscallutility allows you to convert system call numbers to their human-readable equivalents. Use theausyscall --dumpcommand to display a listing of all system calls along with their numbers. For more information, see theausyscall(8) man page.
- success=no
- 
							The successfield records whether the system call recorded in that particular event succeeded or failed. In this case, the call did not succeed.
- exit=-13
- The - exitfield contains a value that specifies the exit code returned by the system call. This value varies for a different system call. You can interpret the value to its human-readable equivalent with the following command:- ausearch --interpret --exit -13 - # ausearch --interpret --exit -13- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Note that the previous example assumes that your Audit log contains an event that failed with exit code - -13.
- a0=7fffd19c5592,- a1=0,- a2=7fffd19c5592,- a3=a
- 
							The a0toa3fields record the first four arguments, encoded in hexadecimal notation, of the system call in this event. These arguments depend on the system call that is used; they can be interpreted by theausearchutility.
- items=1
- 
							The itemsfield contains the number of PATH auxiliary records that follow the syscall record.
- ppid=2686
- 
							The ppidfield records the Parent Process ID (PPID). In this case,2686was the PPID of the parent process such asbash.
- pid=3538
- 
							The pidfield records the Process ID (PID). In this case,3538was the PID of thecatprocess.
- auid=1000
- 
							The auidfield records the Audit user ID, that is the loginuid. This ID is assigned to a user upon login and is inherited by every process even when the user’s identity changes, for example, by switching user accounts with thesu - johncommand.
- uid=1000
- 
							The uidfield records the user ID of the user who started the analyzed process. The user ID can be interpreted into user names with the following command:ausearch -i --uid UID.
- gid=1000
- 
							The gidfield records the group ID of the user who started the analyzed process.
- euid=1000
- 
							The euidfield records the effective user ID of the user who started the analyzed process.
- suid=1000
- 
							The suidfield records the set user ID of the user who started the analyzed process.
- fsuid=1000
- 
							The fsuidfield records the file system user ID of the user who started the analyzed process.
- egid=1000
- 
							The egidfield records the effective group ID of the user who started the analyzed process.
- sgid=1000
- 
							The sgidfield records the set group ID of the user who started the analyzed process.
- fsgid=1000
- 
							The fsgidfield records the file system group ID of the user who started the analyzed process.
- tty=pts0
- 
							The ttyfield records the terminal from which the analyzed process was invoked.
- ses=1
- 
							The sesfield records the session ID of the session from which the analyzed process was invoked.
- comm="cat"
- 
							The commfield records the command-line name of the command that was used to invoke the analyzed process. In this case, thecatcommand was used to trigger this Audit event.
- exe="/bin/cat"
- 
							The exefield records the path to the executable that was used to invoke the analyzed process.
- subj=unconfined_u:unconfined_r:unconfined_t:s0-s0:c0.c1023
- 
							The subjfield records the SELinux context with which the analyzed process was labeled at the time of execution.
- key="sshd_config"
- 
							The keyfield records the administrator-defined string associated with the rule that generated this event in the Audit log.
Second Record
- type=CWD
- In the second record, the - typefield value is- CWD- current working directory. This type is used to record the working directory from which the process that invoked the system call specified in the first record was executed.- The purpose of this record is to record the current process’s location in case a relative path winds up being captured in the associated PATH record. This way the absolute path can be reconstructed. 
- msg=audit(1364481363.243:24287)
- 
							The msgfield holds the same time stamp and ID value as the value in the first record. The time stamp is using the Unix time format - seconds since 00:00:00 UTC on 1 January 1970.
- cwd="/home/user_name"
- 
							The cwdfield contains the path to the directory in which the system call was invoked.
Third Record
- type=PATH
- 
							In the third record, the typefield value isPATH. An Audit event contains aPATH-type record for every path that is passed to the system call as an argument. In this Audit event, only one path (/etc/ssh/sshd_config) was used as an argument.
- msg=audit(1364481363.243:24287):
- 
							The msgfield holds the same time stamp and ID value as the value in the first and second record.
- item=0
- 
							The itemfield indicates which item, of the total number of items referenced in theSYSCALLtype record, the current record is. This number is zero-based; a value of0means it is the first item.
- name="/etc/ssh/sshd_config"
- 
							The namefield records the path of the file or directory that was passed to the system call as an argument. In this case, it was the/etc/ssh/sshd_configfile.
- inode=409248
- The - inodefield contains the inode number associated with the file or directory recorded in this event. The following command displays the file or directory that is associated with the- 409248inode number:- find / -inum 409248 -print - # find / -inum 409248 -print /etc/ssh/sshd_config- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- dev=fd:00
- 
							The devfield specifies the minor and major ID of the device that contains the file or directory recorded in this event. In this case, the value represents the/dev/fd/0device.
- mode=0100600
- 
							The modefield records the file or directory permissions, encoded in numerical notation as returned by thestatcommand in thest_modefield. See thestat(2)man page for more information. In this case,0100600can be interpreted as-rw-------, meaning that only the root user has read and write permissions to the/etc/ssh/sshd_configfile.
- ouid=0
- 
							The ouidfield records the object owner’s user ID.
- ogid=0
- 
							The ogidfield records the object owner’s group ID.
- rdev=00:00
- 
							The rdevfield contains a recorded device identifier for special files only. In this case, it is not used as the recorded file is a regular file.
- obj=system_u:object_r:etc_t:s0
- 
							The objfield records the SELinux context with which the recorded file or directory was labeled at the time of execution.
- nametype=NORMAL
- 
							The nametypefield records the intent of each path record’s operation in the context of a given syscall.
- cap_fp=none
- 
							The cap_fpfield records data related to the setting of a permitted file system-based capability of the file or directory object.
- cap_fi=none
- 
							The cap_fifield records data related to the setting of an inherited file system-based capability of the file or directory object.
- cap_fe=0
- 
							The cap_fefield records the setting of the effective bit of the file system-based capability of the file or directory object.
- cap_fver=0
- 
							The cap_fverfield records the version of the file system-based capability of the file or directory object.
Fourth Record
- type=PROCTITLE
- 
							The typefield contains the type of the record. In this example, thePROCTITLEvalue specifies that this record gives the full command-line that triggered this Audit event, triggered by a system call to the kernel.
- proctitle=636174002F6574632F7373682F737368645F636F6E666967
- 
							The proctitlefield records the full command-line of the command that was used to invoke the analyzed process. The field is encoded in hexadecimal notation to not allow the user to influence the Audit log parser. The text decodes to the command that triggered this Audit event. When searching Audit records with theausearchcommand, use the-ior--interpretoption to automatically convert hexadecimal values into their human-readable equivalents. The636174002F6574632F7373682F737368645F636F6E666967value is interpreted ascat /etc/ssh/sshd_config.
11.6. Using auditctl for defining and executing Audit rules
				The Audit system operates on a set of rules that define what is captured in the log files. Audit rules can be set either on the command line using the auditctl utility or in the /etc/audit/rules.d/ directory.
			
				The auditctl command enables you to control the basic functionality of the Audit system and to define rules that decide which Audit events are logged.
			
File-system rules examples
- To define a rule that logs all write access to, and every attribute change of, the - /etc/passwdfile:- auditctl -w /etc/passwd -p wa -k passwd_changes - # auditctl -w /etc/passwd -p wa -k passwd_changes- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To define a rule that logs all write access to, and every attribute change of, all the files in the - /etc/selinux/directory:- auditctl -w /etc/selinux/ -p wa -k selinux_changes - # auditctl -w /etc/selinux/ -p wa -k selinux_changes- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
System-call rules examples
- To define a rule that creates a log entry every time the - adjtimexor- settimeofdaysystem calls are used by a program, and the system uses the 64-bit architecture:- auditctl -a always,exit -F arch=b64 -S adjtimex -S settimeofday -k time_change - # auditctl -a always,exit -F arch=b64 -S adjtimex -S settimeofday -k time_change- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To define a rule that creates a log entry every time a file is deleted or renamed by a system user whose ID is 1000 or larger: - auditctl -a always,exit -S unlink -S unlinkat -S rename -S renameat -F auid>=1000 -F auid!=4294967295 -k delete - # auditctl -a always,exit -S unlink -S unlinkat -S rename -S renameat -F auid>=1000 -F auid!=4294967295 -k delete- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Note that the - -F auid!=4294967295option is used to exclude users whose login UID is not set.
Executable-file rules
					To define a rule that logs all execution of the /bin/id program, execute the following command:
				
auditctl -a always,exit -F exe=/bin/id -F arch=b64 -S execve -k execution_bin_id
# auditctl -a always,exit -F exe=/bin/id -F arch=b64 -S execve -k execution_bin_id11.7. Defining persistent Audit rules
				To define Audit rules that are persistent across reboots, you must either directly include them in the /etc/audit/rules.d/audit.rules file or use the augenrules program that reads rules located in the /etc/audit/rules.d/ directory.
			
				Note that the /etc/audit/audit.rules file is generated whenever the auditd service starts. Files in /etc/audit/rules.d/ use the same auditctl command-line syntax to specify the rules. Empty lines and text following a hash sign (#) are ignored.
			
				Furthermore, you can use the auditctl command to read rules from a specified file using the -R option, for example:
			
auditctl -R /usr/share/audit/sample-rules/30-stig.rules
# auditctl -R /usr/share/audit/sample-rules/30-stig.rules11.8. Pre-configured Audit rules files for compliance with standards
				To configure Audit for compliance with a specific certification standard, such as OSPP, PCI DSS, or STIG, you can use the set of pre-configured rules files installed with the audit package as a starting point. The sample rules are located in the /usr/share/audit/sample-rules directory.
			
					The Audit sample rules in the sample-rules directory are not exhaustive nor up to date because security standards are dynamic and subject to change. These rules are provided only to demonstrate how Audit rules can be structured and written. They do not ensure immediate compliance with the latest security standards. To bring your system into compliance with the latest security standards according to specific security guidelines, use the SCAP-based security compliance tools.
				
- 30-nispom.rules
- Audit rule configuration that meets the requirements specified in the Information System Security chapter of the National Industrial Security Program Operating Manual.
- 30-ospp-v42*.rules
- Audit rule configuration that meets the requirements defined in the OSPP (Protection Profile for General Purpose Operating Systems) profile version 4.2.
- 30-pci-dss-v31.rules
- Audit rule configuration that meets the requirements set by Payment Card Industry Data Security Standard (PCI DSS) v3.1.
- 30-stig.rules
- Audit rule configuration that meets the requirements set by Security Technical Implementation Guides (STIG).
				To use these configuration files, copy them to the /etc/audit/rules.d/ directory and use the augenrules --load command, for example:
			
cd /usr/share/audit/sample-rules/ cp 10-base-config.rules 30-stig.rules 31-privileged.rules 99-finalize.rules /etc/audit/rules.d/ augenrules --load
# cd /usr/share/audit/sample-rules/
# cp 10-base-config.rules 30-stig.rules 31-privileged.rules 99-finalize.rules /etc/audit/rules.d/
# augenrules --load
				You can order Audit rules using a numbering scheme. See the /usr/share/audit/sample-rules/README-rules file for more information.
			
11.9. Using augenrules to define persistent rules
				The augenrules script reads rules located in the /etc/audit/rules.d/ directory and compiles them into an audit.rules file. This script processes all files that end with .rules in a specific order based on their natural sort order. The files in this directory are organized into groups with the following meanings:
			
- 10
- Kernel and auditctl configuration
- 20
- Rules that could match general rules but you want a different match
- 30
- Main rules
- 40
- Optional rules
- 50
- Server-specific rules
- 70
- System local rules
- 90
- Finalize (immutable)
				The rules are not meant to be used all at once. They are pieces of a policy that should be thought out and individual files copied to /etc/audit/rules.d/. For example, to set a system up in the STIG configuration, copy rules 10-base-config, 30-stig, 31-privileged, and 99-finalize.
			
				Once you have the rules in the /etc/audit/rules.d/ directory, load them by running the augenrules script with the --load directive:
			
11.10. Disabling augenrules
				Use the following steps to disable the augenrules utility. This switches Audit to use rules defined in the /etc/audit/audit.rules file.
			
Procedure
- Copy the - /usr/lib/systemd/system/auditd.servicefile to the- /etc/systemd/system/directory:- cp -f /usr/lib/systemd/system/auditd.service /etc/systemd/system/ - # cp -f /usr/lib/systemd/system/auditd.service /etc/systemd/system/- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Edit the - /etc/systemd/system/auditd.servicefile in a text editor of your choice, for example:- vi /etc/systemd/system/auditd.service - # vi /etc/systemd/system/auditd.service- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Comment out the line containing - augenrules, and uncomment the line containing the- auditctl -Rcommand:- #ExecStartPost=-/sbin/augenrules --load ExecStartPost=-/sbin/auditctl -R /etc/audit/audit.rules - #ExecStartPost=-/sbin/augenrules --load ExecStartPost=-/sbin/auditctl -R /etc/audit/audit.rules- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Reload the - systemddaemon to fetch changes in the- auditd.servicefile:- systemctl daemon-reload - # systemctl daemon-reload- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Restart the - auditdservice:- service auditd restart - # service auditd restart- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
11.11. Setting up Audit to monitor software updates
				You can use the pre-configured rule 44-installers.rules to configure Audit to monitor the following utilities that install software:
			
- 
						dnf[2]
- 
						yum
- 
						pip
- 
						npm
- 
						cpan
- 
						gem
- 
						luarocks
				To monitor the rpm utility, install the rpm-plugin-audit package. Audit will then generate SOFTWARE_UPDATE events when it installs or updates a package. You can list these events by entering ausearch -m SOFTWARE_UPDATE on the command line.
			
					Pre-configured rule files cannot be used on systems with the ppc64le and aarch64 architectures.
				
Prerequisites
- 
						auditdis configured in accordance with the settings provided in Configuring auditd for a secure environment .
Procedure
- Copy the pre-configured rule file - 44-installers.rulesfrom the- /usr/share/audit/sample-rules/directory to the- /etc/audit/rules.d/directory:- cp /usr/share/audit/sample-rules/44-installers.rules /etc/audit/rules.d/ - # cp /usr/share/audit/sample-rules/44-installers.rules /etc/audit/rules.d/- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Load the audit rules: - augenrules --load - # augenrules --load- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- List the loaded rules: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Perform an installation, for example: - dnf reinstall -y vim-enhanced - # dnf reinstall -y vim-enhanced- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Search the Audit log for recent installation events, for example: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
11.12. Monitoring user login times with Audit
				To monitor which users logged in at specific times, you do not need to configure Audit in any special way. You can use the ausearch or aureport tools, which provide different ways of presenting the same information.
			
Prerequisites
- 
						auditdis configured in accordance with the settings provided in Configuring auditd for a secure environment .
Procedure
To display user log in times, use any one of the following commands:
- Search the audit log for the - USER_LOGINmessage type:- ausearch -m USER_LOGIN -ts '12/02/2020' '18:00:00' -sv no - # ausearch -m USER_LOGIN -ts '12/02/2020' '18:00:00' -sv no time->Mon Nov 22 07:33:22 2021 type=USER_LOGIN msg=audit(1637584402.416:92): pid=1939 uid=0 auid=4294967295 ses=4294967295 subj=system_u:system_r:sshd_t:s0-s0:c0.c1023 msg='op=login acct="(unknown)" exe="/usr/sbin/sshd" hostname=? addr=10.37.128.108 terminal=ssh res=failed'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 
								You can specify the date and time with the -tsoption. If you do not use this option,ausearchprovides results from today, and if you omit time,ausearchprovides results from midnight.
- 
								You can use the -sv yesoption to filter out successful login attempts and-sv nofor unsuccessful login attempts.
 
- 
								You can specify the date and time with the 
- Pipe the raw output of the - ausearchcommand into the- aulastutility, which displays the output in a format similar to the output of the- lastcommand. For example:- ausearch --raw | aulast --stdin - # ausearch --raw | aulast --stdin root ssh 10.37.128.108 Mon Nov 22 07:33 - 07:33 (00:00) root ssh 10.37.128.108 Mon Nov 22 07:33 - 07:33 (00:00) root ssh 10.22.16.106 Mon Nov 22 07:40 - 07:40 (00:00) reboot system boot 4.18.0-348.6.el8 Mon Nov 22 07:33- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Display the list of login events by using the - aureportcommand with the- --login -ioptions.- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
dnf is a symlink in RHEL, the path in the dnf Audit rule must include the target of the symlink. To receive correct Audit events, modify the 44-installers.rules file by changing the path=/usr/bin/dnf path to /usr/bin/dnf-3.