STIGfix User's Guide
Release 1.0
E53111-02
October 2015
STIGfix is a tool that you can use to harden guest vServers and physical Oracle Linux nodes on an Exalogic machine, to make them compliant with STIGs (Security Technical Implementation Guides).
STIGs are security configuration standards defined by Defense Information Systems Agency (DISA), an agency of the United States Department of Defense (DoD). For more information about STIGs, go to http://iase.disa.mil/stigs/.
For a list of the STIGs that are addressed by the current version of Oracle STIGfix, see Section 5, "STIGs Addressed by the STIGfix Tool."
This guide contains the following sections:
For a list of the EECS releases that are supported for STIGfix, see the My Oracle Support document ID 1912063.1.
STIGfix is installed automatically when you install the ExaLogic Lifecycle (ELLC) toolkit. For the ELLC installation instructions, see the My Oracle Support document ID 1912063.1.
The STIGfix tool (stigfix) is available in the /exalogic-lctools/bin directory on the compute node on which you installed the ELLC toolkit. To find out the version of the STIGfix tool that is currently installed, go to the /exalogic-lctools/bin directory and run the stigfix --version command.
This section describes the steps that you must perform before running STIGfix.
root Is Not the Only UserAfter you run STIGfix on a compute node or vServer, direct SSH access to that vServer or compute node as the root user will be restricted. So before running STIGfix, check whether root is not the only user that exists on the vServer or compute node that you want to harden by using STIGfix.
If root is the only user, create another user, by using the following commands.
# useradd username # passwd username
The stigfix.json file specifies the STIGs for which the STIGfix tool hardens the target system. For each STIG, the file lists certain fields, some of which are configurable.
You can configure the STIGfix tool to skip hardening the target system for selected STIGs, by setting the enabled field to false for those STIGs.
For certain STIGs, you can configure additional parameters as described in Table 1.
Note:
For these STIGs, use only lower case alphabets to define a parameter.Table 1 Configurable Parameters in stigfix.json
| STIG ID | STIG Title | Configurable Parameter | Default Value | 
|---|---|---|---|
| GEN000580 | The system must require passwords contain a minimum of 14 characters. | 
 | 
 | 
| GEN000590 | The system must use a FIPS 140-2 approved cryptographic hashing algorithm for generating account password hashes. | 
 | 
 | 
| GEN000700 | User passwords must be changed at least every 60 days. | 
 | 
 | 
You can configure the STIGfix tool to completely enable or disable auditing by modifying the audit_script entry in the stigfix.json file. Alternatively, you can disable specific audit rules by modifying the stigfix_audit.rules file.
To configure the STIGfix parameters, complete the following steps:
Open the stigfix.json file in a text editor.
This file exists in the /lib/stigfix subdirectory of the directory on which you mounted the /export/common/exalogic-lctools share.
Look for the STIGs for which you do not want to harden the compute node or vServer.
For each such STIG, set the value of the enabled field to false, as shown in the following example:
{
  "name": "GEN007080",
  "description": "The Datagram Congestion Control Protocol (DCCP) must be disabled unless required.",
  "script": "GEN007080.py",
  "script-params": null,
  "severity": "Medium",
  "enabled": false
},
Caution:
Do not change any field instigfix.json other than those explicitly mentioned in this document.If you want to configure any of the parameters listed in Table 1, identify the relevant STIG in stigfix.json, and change the value of the parameter.
In the following example, the algorithm for generating hashes for account passwords is changed from the default SHA-256 to SHA-512:
{
   "name": "GEN000590",
   "description": "The system must use a FIPS 140-2 approved cryptographic hashing algorithm for generating account password hashes.",
   "script": "GEN000590.sh",
   "script-params": [{
           "name": "hash",
           "value": "sha512"
       }],
   "severity": "Medium",
   "enabled": true  
 },
Caution:
Do not change any field instigfix.json other than those explicitly mentioned in this document.Save and close the stigfix.json file.
To run the STIGfix tool, complete the following steps:
Ensure that you have fulfilled the prerequisites listed in Section 3, "Preparing to Use STIGfix."
SSH, as root, to the compute node or guest vServer that you want to harden.
Mount the ELLC shares by doing the following:
Copy the ELLC installer exalogic-lctools-release_number-installer.sh to the compute node or guest vServer that you want to harden.
Run the following command on the host to which you copied the installation script:
# ./exalogic-lctools-release_number-installer.sh ZFS_Address -m
In this command, ZFS_Address is the host name or IP address of the storage appliance.
For each guest vServer you want to run STIGfix on, ensure that the guest vServer has read/write permissions to the share by doing the following:
Log in to the ZFS Storage Appliance BUI at https://ZFS_Address:215 as the root user.
Click the Shares tab.
Find and select the common / exalogic-lctools share and click the edit entry icon.
The details of the share are displayed.
Click the Protocols tab.
Click the plus (+) button next to NFS Exceptions, and specify the following for each guest vServer on which you want to run STIGfix:
Type: Network
Entity: ip_address_of_vserver/32 (in CIDR format)
Access mode: Read/write
Charset: default
Root Access: Selected
Click the Apply button near the upper right corner.
Go to the bin subdirectory within the directory on which the /export/common/exalogic-lctools share is mounted:
Example:
# cd /exalogic-lctools/bin
Run the following command:
# sh ./stigfix
Note:
The STIGfix tool may display an error for GEN003080-2 because asymlink under /etc/cron.daily will continue to have permission mode 0777. You can ignore this error.Perform the manual hardening steps described in the following table:
| STIG | Manual Steps | 
|---|---|
| GEN008700: The system boot loader must require authentication | Run the GEN008700.pyscript, which is available in the/lib/stigfix/scriptssubdirectory of the directory on which you mounted the/export/common/exalogic-lctoolsshare. This script adds a password for the grub bootloader. | 
Reboot the compute node or guest vServer:
# reboot -n
The compute node or guest vServer reboots.
After the compute node or guest vServer reboots, you are prompted to enter new passwords which are STIG compliant.
The STIGfix tool hardens the system for all the STIG IDs listed in Section 5, "STIGs Addressed by the STIGfix Tool."
It creates a log file in the /var/log directory on the compute node or guest vServer on which you ran STIGfix, in the format stigfix.YYMMDDHHMMSS.log. The following is an example of a log file created by STIGfix:
stigfix.140624123608.log
For each file that the STIGfix tool updates, it creates a backup in the /lib/stigfix/backups directory of the directory on which you mounted the /export/common/exalogic-lctools share, in the format FIX_NAME-FILE_NAME.bakYYYYMMDD.HHMMSS.NN, where NN is milliseconds. The following is an example of a backup file created by STIGfix:
GEN005550.py-sshd_config.bak20140429.003034.53 GEN003610.sh-sysctl.conf.bak20140429.003035.42
The list of STIGs addressed by the STIGfix tool varies based on the version of Oracle Linux that you are running. This section contains the following topics:
Section 5.1, "STIGs Addressed by the STIGfix Tool for Oracle Enterprise Linux 5"
Section 5.2, "STIGs Addressed by the STIGfix Tool For Oracle Enterprise Linux 6"
The following table lists the STIGs that are addressed by the current version of STIGfix.
| STIG ID | STIG Title | 
|---|---|
| GEN000000-LNX00320 | The system must not have special privilege accounts such as shutdown and halt. | 
| GEN000000-LNX00440 | The /etc/security/access.conffile must have mode0640or less permissive. | 
| GEN000000-LNX00520 | The /etc/sysctl.conffile must have mode0600or less permissive. | 
| GEN000000-LNX00580 | The x86 CTRL-ALT-DELETE key sequence must be disabled. | 
| GEN000020 | The system must require authentication upon booting into single-user and maintenance modes. (CCE-4241-6) | 
| GEN000252 | The time synchronization configuration file (such as /etc/ntp.conf) must have mode0640or less permissive. | 
| GEN000290-2 | The system must not have the unnecessary (news) account. | 
| GEN000290-3 | The system must not have the unnecessary (gopher) account. | 
| GEN000290-4 | The system must not have the unnecessary (ftp) account. | 
| GEN000460 | The system must disable accounts after three consecutive unsuccessful login attempts. | 
| GEN000500-2 | The graphical desktop environment must set the idle timeout to no more than 15 minutes. | 
| GEN000500-3 | Graphical desktop environments provided by the system must have automatic lock enabled. | 
| GEN000540 | Users must not be able to change passwords more than once every 24 hours. | 
| GEN000560 | The system must not have accounts configured with blank or null passwords. | 
| GEN000580 | The system must require passwords contain a minimum of 14 characters. | 
| GEN000590 | The system must use a FIPS 140-2 approved cryptographic hashing algorithm for generating account password hashes. | 
| GEN000600 | The system must require passwords contain at least one uppercase alphabetic character. | 
| GEN000610 | The system must require passwords contain at least one lowercase alphabetic character. | 
| GEN000620 | The system must require passwords contain at least one numeric character. | 
| GEN000640 | The system must require passwords contain at least one special character. | 
| GEN000680 | The system must require passwords contain no more than three consecutive repeating characters. | 
| GEN000700 | User passwords must be changed at least every 60 days. | 
| GEN000750 | The system must require at least four characters be changed between the old and new passwords during a password change. | 
| GEN000800 | The system must prohibit the reuse of passwords within five iterations. | 
| GEN000920 | The rootaccount's home directory (other than/) must have mode0700. | 
| GEN000940 | The rootaccount's executable search path must be the vendor default and must contain only absolute paths. | 
| GEN000980 | The system must prevent the rootaccount from directly logging in except from the system console. | 
| GEN001120 | The system must not permit rootlogins using remote access programs such asssh. | 
| GEN001720 | All global initialization files must have mode 0644 or less permissive. | 
| GEN002100 | The .rhostsfile must not be supported in PAM. | 
| GEN002720 | The audit system must be configured to audit failed attempts to access files and programs. | 
| GEN002720-2 | The audit system must be configured to audit failed attempts to access files and programs. | 
| GEN002720-3 | The audit system must be configured to audit failed attempts to access files and programs. | 
| GEN002720-4 | The audit system must be configured to audit failed attempts to access files and programs. | 
| GEN002720-5 | The audit system must be configured to audit failed attempts to access files and programs. | 
| GEN002752 | The audit system must be configured to audit account disabling. | 
| GEN002760-10 | The audit system must be configured to audit all administrative, privileged, and security actions. | 
| GEN002760-2 | The audit system must be configured to audit all administrative, privileged, and security actions. | 
| GEN002760-3 | The audit system must be configured to audit all administrative, privileged, and security actions. | 
| GEN002760-4 | The audit system must be configured to audit all administrative, privileged, and security actions. | 
| GEN002760-6 | The audit system must be configured to audit all administrative, privileged, and security actions. | 
| GEN002760-7 | The audit system must be configured to audit all administrative, privileged, and security actions. | 
| GEN002760-8 | The audit system must be configured to audit all administrative, privileged, and security actions. | 
| GEN002760-9 | The audit system must be configured to audit all administrative, privileged, and security actions. | 
| GEN002800 | The audit system must be configured to audit login, logout, and session initiation. | 
| GEN002820 | The audit system must be configured to audit all discretionary access control permission modifications. | 
| GEN002820-10 | The audit system must be configured to audit all discretionary access control permission modifications. | 
| GEN002820-11 | The audit system must be configured to audit all discretionary access control permission modifications. | 
| GEN002820-12 | The audit system must be configured to audit all discretionary access control permission modifications. | 
| GEN002820-13 | The audit system must be configured to audit all discretionary access control permission modifications. | 
| GEN002820-2 | The audit system must be configured to audit all discretionary access control permission modifications. | 
| GEN002820-3 | The audit system must be configured to audit all discretionary access control permission modifications. | 
| GEN002820-4 | The audit system must be configured to audit all discretionary access control permission modifications. | 
| GEN002820-5 | The audit system must be configured to audit all discretionary access control permission modifications. | 
| GEN002820-6 | The audit system must be configured to audit all discretionary access control permission modifications. | 
| GEN002820-7 | The audit system must be configured to audit all discretionary access control permission modifications. | 
| GEN002820-8 | The audit system must be configured to audit all discretionary access control permission modifications. | 
| GEN002820-9 | The audit system must be configured to audit all discretionary access control permission modifications. | 
| GEN002825-3 | The audit system must be configured to audit the loading and unloading of dynamic kernel modules - /sbin/insmod. | 
| GEN002825-4 | The audit system must be configured to audit the loading and unloading of dynamic kernel modules - /sbin/modprobe. | 
| GEN002825-5 | The audit system must be configured to audit the loading and unloading of dynamic kernel modules - /sbin/rmmod. | 
| GEN003060 | Default system accounts (with the exception of root) must not be listed in thecron.allowfile or must be included in the cron.deny file if thecron.allowfile does not exist. | 
| GEN003080 | Crontab files must have mode 0600or less permissive and files incronscript directories must have mode0700or less. | 
| GEN003080-2 | Files in cronscript directories must have mode0700or less permissive. | 
| GEN003200 | The cron.denyfile must have mode0600or less permissive. | 
| GEN003320 | Default system accounts (with the exception of root) must not be listed in theat.allowfile or must be included in theat.denyfile if theat.allowfile does not exist. | 
| GEN003609 | The system must ignore IPv4 Internet Control Message Protocol (ICMP) redirect messages. | 
| GEN003610 | The system must not send IPv4 Internet Control Message Protocol (ICMP) redirects. | 
| GEN003740 | The xinetdconfiguration files must have mode0640or less permissive. | 
| GEN003810 | The portmaporrpcbindservice must not be running unless needed. | 
| GEN004000 | The traceroutefile must have mode0700or less permissive. | 
| GEN004540 | The SMTP service HELP command must not be enabled. | 
| GEN004580 | The system must not use .forwardfiles. | 
| GEN005040 | All FTP users must have a default umaskof077. | 
| GEN005320 | The snmpd.conffile must have mode0600or less permissive. | 
| GEN005390 | The /etc/syslog.conffile must have mode0640or less permissive. | 
| GEN005501 | The SSH client must be configured to only use the SSHv2 protocol. | 
| GEN005505 | The SSH daemon must be configured to only use FIPS 140-2 approved ciphers. | 
| GEN005507 | The SSH daemon must be configured to only use Message Authentication Codes (MACs) employing FIPS 140-2 approved cryptographic hash algorithms. | 
| GEN005550 | The SSH daemon must be configured with the Department of Defense (DoD) logon banner. This file contains the banner message which will be displayed to any user accessing the hardened system. Users should modify this file to add their company policy or banner message before applying STIGfix. | 
| GEN007020 | The Stream Control Transmission Protocol (SCTP) must be disabled unless required. | 
| GEN007080 | The Datagram Congestion Control Protocol (DCCP) must be disabled unless required. | 
| GEN007480 | The Reliable Datagram Sockets (RDS) protocol must be disabled or not installed unless required. | 
| GEN007540 | The Transparent Inter-Process Communication (TIPC) protocol must be disabled or uninstalled. | 
| GEN007660 | The Bluetooth protocol handler must be disabled or not installed. | 
| GEN008020 | If the system is using LDAP for authentication or account information, the LDAP TLS connection must require that the server provide a certificate with a valid trust path to a trusted CA. | 
| GEN008040 | If the system is using LDAP for authentication or account information, the system must verify that the LDAP server's certificate has not been revoked. | 
| GEN008700 | The system boot loader must require authentication. | 
The following table lists the STIGs addressed by STIGfix tool for Oracle Enterprise Linux 6
| STIG ID | STIG Title | 
|---|---|
| CCE-26242-8 | The audit system must be configured to audit all attempts to alter system time using the adjtimexcommand. | 
| CCE-26280-8 | Record events that modify the system's discretionary access controls: chmod. | 
| CCE-26573-6 | Ensure auditdcollects information on exporting to media successfully. | 
| CCE-26651-0 | Ensure auditdcollects file deletion events by the user. | 
| CCE-26657-7 | Record events that modify the system's mandatory access controls. | 
| CCE-26662-7 | Ensure auditdcollects the system administrator's actions. | 
| CCE-26664-3 | Record events that modify user or group information. | 
| CCE-26831-8 | Disable kernel parameter for accepting secure redirects by default. | 
| CCE-26854-0 | Disable kernel parameter for accepting secure redirects for all interfaces. | 
| CCE-26915-9 | Enable kernel parameter to use reverse path filtering by default. | 
| CCE-26969-6 | Ensure Security-Enhanced Linux (SELinux) state is enforcing. | 
| CCE-26979-5 | Enable kernel parameter to use reverse path filtering for all interfaces. | 
| CCE-26993-6 | Enable kernel parameter to ignore bogus ICMP error responses. | 
| CCE-27002-5 | Set password hashing algorithm in /etc/login.defs. | 
| CCE-27015-7 | Disable kernel parameter for accepting ICMP redirects by default. | 
| CCE-27018-1 | Enable iptables. | 
| CCE-27027-2 | Disable kernel parameter for accepting ICMP redirects for all interfaces. | 
| CCE-27037-1 | Disable kernel parameter for accepting source-routed packets for all interfaces. | 
| CCE-27066-0 | Enable kernel parameter to log martian packets. | 
| CCE-27153-6 | Disable IPv6 networking support automatic loading. | 
| CCE-27166-8 | Disable accepting IPv6 redirects by setting net.ipv6.conf.default.accept_redirectsto 0. | 
| CCE-27170-0 | Record attempts to alter time through clock_settime. | 
| CCE-27172-6 | The audit system must be configured to audit all attempts to alter system time through /etc/localtime. | 
| CCE-27173-4 | Record events that modify the system's discretionary access controls: chown. | 
| CCE-27174-2 | Record events that modify the system's discretionary access controls: fchmod. | 
| CCE-27175-9 | Record events that modify the system's discretionary access controls: fchmodat. | 
| CCE-27177-5 | Record events that modify the system's discretionary access controls: fchown. | 
| CCE-27178-3 | Record events that modify the system's discretionary access controls: fchownat. | 
| CCE-27179-1 | Record events that modify the system's discretionary access controls: fremovexattr. | 
| CCE-27180-9 | Record events that modify the system's discretionary access controls: fsetxattr. | 
| CCE-27181-7 | Record events that modify the system's discretionary access controls: lchown. | 
| CCE-27182-5 | Record events that modify the system's discretionary access controls: lremovexattr. | 
| CCE-27183-3 | Record events that modify the system's discretionary access controls: lsetxattr. | 
| CCE-27184-1 | Record events that modify the system's discretionary access controls: removexattr. | 
| CCE-27185-8 | Record events that modify the system's discretionary access controls: setxattr. | 
| CCE-27203-9 | Record attempts to alter time through settimeofday. | 
| CCE-27228-6 | Set password hashing algorithm in /etc/login.defs. Preferred is SHA512. | 
| CCE-27238-5 | Configure auditd space_left_actionon low disk space to email. | 
| CCE-27247-6 | Disable automatic bug reporting tool ( abrtd). | 
| CCE-27283-1 | Limit the number of concurrent login sessions allowed per user. | 
| CCE-27291-4 | Set last log in or access notification. | 
| CCE-27457-1 | Limit the number of concurrent login sessions allowed per user. | 
For information about Oracle's commitment to accessibility, visit the Oracle Accessibility Program website at http://www.oracle.com/pls/topic/lookup?ctx=acc&id=docacc.
Oracle customers that have purchased support have access to electronic support through My Oracle Support. For information, visit http://www.oracle.com/pls/topic/lookup?ctx=acc&id=info or visit http://www.oracle.com/pls/topic/lookup?ctx=acc&id=trs if you are hearing impaired.
Oracle Exalogic Elastic Cloud STIGfix User’s Guide, Release 1.0
E53111-02
Copyright © 2010, 2015, Oracle and/or its affiliates. All rights reserved.
This software and related documentation are provided under a license agreement containing restrictions on use and disclosure and are protected by intellectual property laws. Except as expressly permitted in your license agreement or allowed by law, you may not use, copy, reproduce, translate, broadcast, modify, license, transmit, distribute, exhibit, perform, publish, or display any part, in any form, or by any means. Reverse engineering, disassembly, or decompilation of this software, unless required by law for interoperability, is prohibited.
The information contained herein is subject to change without notice and is not warranted to be error-free. If you find any errors, please report them to us in writing.
If this is software or related documentation that is delivered to the U.S. Government or anyone licensing it on behalf of the U.S. Government, then the following notice is applicable:
U.S. GOVERNMENT END USERS: Oracle programs, including any operating system, integrated software, any programs installed on the hardware, and/or documentation, delivered to U.S. Government end users are "commercial computer software" pursuant to the applicable Federal Acquisition Regulation and agency-specific supplemental regulations. As such, use, duplication, disclosure, modification, and adaptation of the programs, including any operating system, integrated software, any programs installed on the hardware, and/or documentation, shall be subject to license terms and license restrictions applicable to the programs. No other rights are granted to the U.S. Government.
This software or hardware is developed for general use in a variety of information management applications. It is not developed or intended for use in any inherently dangerous applications, including applications that may create a risk of personal injury. If you use this software or hardware in dangerous applications, then you shall be responsible to take all appropriate fail-safe, backup, redundancy, and other measures to ensure its safe use. Oracle Corporation and its affiliates disclaim any liability for any damages caused by use of this software or hardware in dangerous applications.
Oracle and Java are registered trademarks of Oracle and/or its affiliates. Other names may be trademarks of their respective owners.
Intel and Intel Xeon are trademarks or registered trademarks of Intel Corporation. All SPARC trademarks are used under license and are trademarks or registered trademarks of SPARC International, Inc. AMD, Opteron, the AMD logo, and the AMD Opteron logo are trademarks or registered trademarks of Advanced Micro Devices. UNIX is a registered trademark of The Open Group.
This software or hardware and documentation may provide access to or information about content, products, and services from third parties. Oracle Corporation and its affiliates are not responsible for and expressly disclaim all warranties of any kind with respect to third-party content, products, and services unless otherwise set forth in an applicable agreement between you and Oracle. Oracle Corporation and its affiliates will not be responsible for any loss, costs, or damages incurred due to your access to or use of third-party content, products, or services, except as set forth in an applicable agreement between you and Oracle.