Skip to content

Latest commit

 

History

History
260 lines (206 loc) · 12.1 KB

File metadata and controls

260 lines (206 loc) · 12.1 KB

Lab 7: How to use the Audit Intrusion Detection Environment (AIDE)

Goal of Lab

The goal of this lab exercise is to understand how to use the Audit Intrusion Detection Environment (AIDE).

We want to achieve the following objectives in this exercise:

  • Install AIDE on your servera system

  • Initialize a baseline scan to capture current state

  • Modify permissions and content on a select file

  • Run a scan to identify drift from the baseline

  • Set audit watches to capture who, when, and how

Introduction

AIDE maintains a database that captures the state of critical system configuration files at a point in time, allowing for subsequent analysis to identify drift from a desired state. AIDE is able to determine what changes were made to a system, but is not able to determine who made the change, when the change occurred, and what command was used to make the change. For that, we will use auditd and ausearch, which are installed and enabled by default.

AIDE and audit watches are complementary security tools that can help you harden your environment. AIDE allows you to configure files and directories that you want to watch, and audit watches allow you to determine who, when, and how a particular change occurred. These can be fine tuned over time to include scans of custom files and directories, and watches over files and directories you deem most critical. More information can be found by reviewing the Red Hat Enterprise Linux Security Guide.

Lab 7.1 Installing the AIDE package

  1. If not already there, log into to the workstation bastion host as lab-user from your desktop system replacing GUID with your lab’s GUID. Use the password r3dh4t1!

    [localhost ~]$ ssh lab-user@workstation-GUID.rhpds.opentlc.com
  2. Log into the servera.example.com host as root.

    [lab-user@workstation-GUID ~]$ ssh root@servera.example.com
  3. AIDE is part of the base repository that comes standard with Red Hat Enterprise Linux, but is not installed by default. As root, install the AIDE package.

    [root@servera ~]# yum search aide
    [root@servera ~]# yum install aide.x86_64
  4. After you have installed AIDE, review the configuration file located at:

    [root@servera ~]# less /etc/aide.conf
    (Type q to exit less)
  5. A review of this file will show you the directories and files that are scanned by default and provide a list of what is checked (e.g. permissions, checksums, etc.). You can also refer to the man page as follows:

    [root@servera ~]# man aide

Lab 7.2 Initializing a Baseline Scan

Organizations often create a locked down standard operating build for provisioning a server. This includes configuration of the operating system and other software packages.

  1. After you have provisioned a server, or after you have made configuration changes to an existing server, initiate an AIDE scan as follows:

    [root@servera ~]# aide --init
  2. The previous step does take a few minutes, so you may want to read ahead as you wait. Upon completion you should see output similar to:

    AIDE, version 0.15.1
    ### AIDE database at /var/lib/aide/aide.db.new.gz initialized.
  3. To complete the initialization, rename or copy the database file by removing the new. from the generated file name as follows:

    [root@servera ~]# mv /var/lib/aide/aide.db.new.gz /var/lib/aide/aide.db.gz
  4. You now have a baseline scan derived from the rules setup in /etc/aide.conf. Note that we used the --init parameter (or -i) to initialize the baseline. In subsequent scans, we will use --check (or -C) to check for changes. Run a check as follows:

    [root@servera ~]#  aide --check
  5. This scan should not disclose any deviations from the baseline and return:

    AIDE, version 0.15.1
    ### All files match AIDE database. Looks okay!

Lab 7.3 Modifying Permissions and Contents of a File

  1. Let’s review the /etc/aide.conf file and look for entries related to ssh. At line 273 you will find the following entries:

    [root@servera ~]# less /etc/aide.conf
    
    Using the less command, you can jump to line 273 by typing 273g. When you do that, you should see these two lines at the top:
    
    /etc/ssh/sshd_config$ CONTENT_EX
    /etc/ssh/ssh_config$ CONTENT_EX
  2. What this means is that AIDE is monitoring these two files and is looking specifically for changes to extended content. At line 88, you will find the definition for CONTENT_EX:

    [root@servera ~]# less /etc/aide.conf
    
    Using the less command, you can jump to line 88 by typing 88g. When you do that, you should see these lines at the top:
    
    # Extended content + file type + access.
    CONTENT_EX = sha256+ftype+p+u+g+n+acl+selinux+xattrs
  3. A review of the default rules beginning at line 26 lists the parameters that are included. For this exercise we will alter the permissions and content of /etc/ssh/sshd_config, and rerun our scan.

    [root@servera ~]# less /etc/aide.conf
    
    Using the less command, you can jump to line 26 by typing 26g. When you do that you should see the list of the parameters that are included. Type q to exit less.
    
    [root@servera ~]# chmod 0644 /etc/ssh/sshd_config
    [root@servera ~]# vim /etc/ssh/sshd_config
  4. Using vim, jump to the end of the /etc/ssh/sshd_config file by typing Shift + g. Then, press the letter o to add a line to the end of the file. Type UseDNS no to the end of the /etc/ssh/sshd_config file. Then, press esc and save and exit by pressing :wq!

  5. When we run AIDE, we expect it to note the change of the permissions and identify a change in the checksum of the file.

  6. Now let’s run a new scan and confirm.

    [root@servera ~]# aide --check
  7. We see that AIDE checked nearly 60,000 files:

    [root@servera ~]$ aide --check
    AIDE 0.15.1 found differences between database and filesystem!!
    Start timestamp: 2018-02-23 12:53:21
    Summary:
      Total number of files:    58340
      Added files:            0
      Removed files:        0
      Changed files:        1
    Changed files:
    changed: /etc/ssh/sshd_config
    Detailed information about changes:
    File: /etc/ssh/sshd_config
     Perm     : -rw-------                       , -rw-r--r--
     SHA256   : hut7+4Tf5IcWGsNJ++oCqcLIDeTnu5yk , a7+ICZ7ykTPkxJr9DswwuIS5Z/pOCcyq
  8. We can see which permissions specifically changed, which is also the case when other attributes such as user, group, or file type change. As for content, we can only see that the checksum changes and we would have to recover a previous version of the file to determine the exact content change. What we can’t tell is the userid who made this change, or what time and how that change was made.

  9. For that we would need to set audit watches.

  10. Revert the changes you made in this exercise before proceeding to the next exercise by setting the permissions of sshd_config back to 0600 and removing UseDNS no from the end of the file.

    [root@servera ~]# chmod 0600 /etc/ssh/sshd_config
    [root@servera ~]# vim /etc/ssh/sshd_config
  11. Using vim, jump to the end of the /etc/ssh/sshd_config file by typing Shift + g. Then, delete the last time that we added previously by pressing dd on the last line, UseDNS no. Then, save and exit by pressing :wq!

  12. Run aide --check again to verify that you have reverted back correctly.

    [root@servera ~]# aide --check

Lab 7.4 Setting Audit Watches

  1. The auditd daemon is installed and enabled by default in Red Hat Enterprise Linux. Log files reside at /var/log/audit/audit.log based on the configuration in /etc/audit/auditd.conf and the watches in /etc/audit/rules.d/audit.rules. Audit watches can be set dynamically for the duration of the runtime, or permanently by adding a file to the /etc/audit/rules.d/ directory.

  2. First, we will enable a dynamic rule at the command line and check a specific file for permissions and attribute changes. We will do this by using the auditctl command. A full list of watch parameters can be found by reviewing the man page. For this exercise, let’s set a watch and establish a key for the /etc/shadow file as follows:

    [root@servera ~]# auditctl -w /etc/shadow -pa -k shadow_key
    • The -w indicates that we are watching the /etc/shadow file.

    • The -pa parameter indicates permissions and attributes are what we are watching.

    • The -k parameter indicates that we have created a key that we can use to search the audit log.

  3. Let’s check for active watches by running the following command:

    [root@servera ~]# auditctl -l
    
    -w /etc/shadow -p a -k shadow_key
  4. Now let’s change the permission on the /etc/shadow file, run a scan, and then look for the entry in the audit.log.

    [root@servera ~]$ chmod 0644 /etc/shadow
    [root@servera ~]$ aide --check
    AIDE 0.15.1 found differences between database and filesystem!!
    Start timestamp: 2018-02-23 13:44:27
    Summary:
      Total number of files:    46010
      Added files:            0
      Removed files:        0
      Changed files:        1
    Changed files:
    changed: /etc/shadow
    Detailed information about changes:
    File: /etc/shadow
     Perm     : ----------                       , -rw-r--r--
     ACL      : old = A:
    user::---
    group::---
    other::---
                      D: <NONE>
                new = A:
    user::rw-
    group::r--
    other::r--
                      D: <NONE>
  5. We can clearly see that the permissions on the /etc/shadow file changed, and because we set an audit watch on this file, we can now search for the key in audit log by using the ausearch command that comes with auditd. Run the following command using the key you created above:

    [root@servera ~]$ ausearch -i -k shadow_key
  6. This command returns the following entry in the audit.log:

    time->Fri Feb 23 13:44:22 2018
    type=PROCTITLE msg=audit(1519415062.738:424): proctitle=63686D6F640030363434002F6574632F736861646F77
    type=PATH msg=audit(1519415062.738:424): item=0 name="/etc/shadow" inode=17550675 dev=fd:00 mode=0100644 ouid=0 ogid=0 rdev=00:00 obj=system_u:object_r:shadow_t:s0 objtype=NORMAL cap_fp=0000000000000000 cap_fi=0000000000000000 cap_fe=0 cap_fver=0
    type=CWD msg=audit(1519415062.738:424):  cwd="/home/student"
    type=SYSCALL msg=audit(1519415062.738:424): arch=c000003e syscall=268 success=yes exit=0 a0=ffffffffffffff9c a1=fa10f0 a2=1a4 a3=7ffd9b292720 items=1 ppid=20229 pid=20230 auid=1000 uid=0 gid=0 euid=0 suid=0 fsuid=0 egid=0 sgid=0 fsgid=0 tty=pts0 ses=1 comm="chmod" exe="/usr/bin/chmod" subj=unconfined_u:unconfined_r:unconfined_t:s0-s0:c0.c1023 key="shadow_key"
  7. While there are many attributes in the log entry, five are of particular interest and have been highlighted:

    • msg-audit - timestamp

    • name - object acted upon

    • auid - login id of the user who made the change (student)

    • uid - login id of the user who ran the command (root)

    • key - the search key that we setup earlier

  8. If we decide we want to keep this watch, we need to make it permanent. We do this by placing a watch in the /etc/audit/rules.d/audit.rules file. You insert the command in the file as you typed it on the command line, but you remove the the term auditctl.

  9. Place the following in the /etc/audit/rules.d/audit.rules file:

    -w /etc/shadow -pa -k shadow_key
    
    [root@servera ~]$ vim /etc/audit/rules.d/audit.rules
  10. In vim, type the letter o to begin a new line below the cursor and insert the text above. Press esc and then save and exit by pressing :wq!.

  11. When the service restarts you can run auditctl -l to verify that your rule has survived. Note that your auditd is configured to manual start and stop, so you will have to reboot the server to see this change. If you want to configure a watch, but do not want to reboot your server, create a dynamic rule as we have in this exercise, and then update the audit.rules file for when your server reboots.

  12. If you want to reboot your server to verify that your rule has survived, do the following:

    [root@servera ~]$ reboot
    [lab-user@workstation-GUID ~]$ ssh root@servera.example.com
    [root@servera ~]$ auditctl -l
    -w /etc/shadow -pa -k shadow_key