tripwire.txt v. 11 Sept 2013 Introduction to Tripwire, with Gentoo-specific installation information Tripwire software can monitor the integrity of critical system files and directories by identifying specified changes made to selected system files and directories. Configure Tripwire software to monitor your system in the way that is best for you. Tripwire software works by comparing files and directories against a defined baseline, stored in a tripwire-created database. Tripwire generates the baseline by taking a "snapshot" of specified files and directories. Tripwire software then compares the current system against the baseline and reports modifications, additions, or deletions. Use Tripwire software for system security, intrusion detection, damage assessment, and recovery forensics. To set-up Tripwire Configuration The Tripwire tarball installs the basic program files needed to run the software. However, this installation does not prepare the configuration files that Tripwire needs to perform correctly. After you install the tripwire executable files and example configuration, you must: 1. Review and perhaps edit the plain-text tripwire configuration file (/etc/tripwire/twcfg.txt) with a text editor, if desired. 2. Either run a configuration script (twsetup.sh from Gentoo's mktwpol package, or tripwire-setup-keyfiles from Red Hat, or deprecated twinstall.sh, also from Red Hat), or run the program `twadmin` with the correct command line switches to make key files and encrypt/sign the tripwire configuration file. Make site key file ------------------ `twadmin --generate-keys -S /etc/tripwire/site.key` Make local key file ------------------- `twadmin --generate-keys -L /etc/tripwire/$HOSTNAME-local.key` Make mandatory signed tripwire configuration file (tw.cfg) ---------------------------------------------------------- `twadmin --create-cfgfile -S /etc/tripwire/site.key /etc/tripwire/twcfg.txt` Note: Once encrypted/signed, the configuration file, tw.cfg, must not be renamed or moved. The plain-text tripwire configuration file (twcfg.txt) should be deleted. It can be recreated with `twadmin --print-cfgfile` 3. Make a plain-text policy file. The use of the name twpol.txt is common, but the name of this file is not defined or used by Tripwire, other than preparation of the encrypted/signed policy file. To make the plain-text policy file, either run a policy file generator (for example, mktwpol.sh from Gentoo's mktwpol package), or edit the plain-text policy file (twpol-GENERIC.txt, or twpol.txt, or similar) with a text editor. The plain-text policy file should not refer to any non-existent file or directory. If you edit twpol-GENERIC.txt to act as your plain-text policy file, provide your system's HOSTNAME at line 61. If you don't provide the correct HOSTNAME, a tripwire inspection of the target computer's filesystem will fail to check the tripwire database file for changes. TWDB=/var/lib/tripwire/YOUR_HOSTNAME.twd; 4. Convert the plain-text policy file into the encrypted/signed form that tripwire will refer to as it examines the files on the target computer's filesystem. The default filename for the encrypted/signed policy file is defined in the tripwire configuration file (tw.cfg) and is usually tw.pol. The encryption/signing of plain-text twpol.txt is done with yet another `twadmin` command line. Make mandatory encrypted/signed system inspection policy file -------------------------------------------------------------- `twadmin -m P -c /etc/tripwire/tw.cfg /etc/tripwire/twpol.txt` Note: If you modify the plain-text policy file after running the configuration script, you must re-sign the plain-text policy file before initializing the database file. Tripwire baseline database creation and inspections refer to the encrypted/signed policy file, not to the plain-text policy file. Note: The plain-text tripwire policy file (twpol.txt) should be deleted. It can be recreated with `twadmin --print-polfile` 5. Initialize the Tripwire database file. Record current file attributes in the tripwire database ------------------------------------------------------- `tripwire --init -c /etc/tripwire/tw.cfg` Note: Tripwire might issue some "Warning: File system error" errors, and appear to hang. But as long as it follows with "### Continuing...", it is still working. 6. Run the first integrity check. `tripwire --check -c /etc/tripwire/tw.cfg` Note: The use of "-c /etc/tripwire/tw.cfg" is not required if Tripwire uses the default tripwire configuration directory and file names. If you defer to tripwire default filenames, then updating a text policy file into a tripwire database, and running an integrity check, can be done with these commands: `twadmin --create-polfile /etc/tripwire/twpol.txt` `tripwire --init` `tripwire --check` Modifying the Policy File How Tripwire software checks your system is specified in the Tripwire plain-text policy file (twpol.txt). A default policy file is included in the Tripwire software installation. This policy file should be tailored to fit your particular system. Tailoring the policy file is necessary to take advantage of Tripwire software's ability to monitor changes on your system. The plain-text policy file is usually located at /etc/tripwire/twpol.txt. An example policy file (located at /etc/tripwire/twpol-GENERIC.txt, or at /usr/share/doc/tripwire-VER#-REL#/policyguide.txt) is included to help you learn the policy language. Read the sample policy files and the comments in the sample policy file to learn the policy language. After you modify the plain-text policy file, don't forget! encrypt/sign using `twadmin --create-polfile /etc/tripwire/twpol.txt` Selecting Passphrases Tripwire files are encrypted/signed using site or local keys. These keys are protected by passphrases. When selecting passphrases, the following recommendations apply: Use at least eight alphanumeric and symbolic characters for each passphrase. The maximum length of a passphrase is 1023 characters. Quotes should not be used as passphrase characters. Assign a unique passphrase for the site key. The site key passphrase protects the site key, which is used to sign Tripwire software configuration and policy files. Assign a unique passphrase for the local key. The local key signs the Tripwire baseline database file. The local key may sign the Tripwire report files also. Store the passphrases in a secure location. There is no way to remove encryption from a signed file if you forget your passphrase and lost the key files. If you forget the passphrases, the files are unusable. In that case you must create new key files and the baseline database. Initializing the Database In Database Initialization mode, Tripwire software builds a database of filesystem objects based on the rules in the policy file. This database serves as the baseline for integrity checks. The syntax for Database Initialization mode is: `tripwire --init -c /etc/tripwire/tw.cfg` Running an Integrity Check The Integrity Check mode compares the current file system objects with their properties recorded in the Tripwire database. Violations are printed to stdout. The report file is saved and can later be accessed by twprint. An email option enables you to send email. The syntax for Integrity Check mode is: `tripwire --check -c /etc/tripwire/tw.cfg` Printing Reports - twprint Print Report Mode The twprint --print-report mode prints the contents of a Tripwire report. If you do not specify a report with the --twrfile or -r command-line argument, the default report file specified by the configuration file REPORTFILE variable is used. Example: On a machine named LIGHTHOUSE, the command could be: `twprint -m r --twrfile LIGHTHOUSE-19990622-021212.twr` Updating the Database after an Integrity Check Database Update mode enables you to update the Tripwire database after an integrity check if you determine that the violations discovered are valid. This update process saves time by enabling you to update the database without having to re-initialize it. It also enables selective updating, which cannot be done through re-initialization. The syntax for Database Update mode is: `tripwire --update` Updating the Policy File Change the way that Tripwire software scans the system by changing the rules in the policy file. You can then update the database without a complete re-initialization. This saves a significant amount of time and preserves security by keeping the policy file synchronized with the database it uses. The syntax for Policy Update mode is: `tripwire --update-policy` Testing email functions Test mode tests the software's email notification system, using the settings currently specified in the configuration file. The syntax for Email Test Reporting mode is: `tripwire --test` Tripwire Components The policy file begins as a text file containing comments, rules, directives, and variables. These dictate the way Tripwire software checks your system. Each rule in the policy file specifies a system object to be monitored. Rules also describe which changes to the object to report, and which to ignore. System objects are the files and directories you wish to monitor. Each object is identified by an object name. A property refers to a single characteristic of an object that Tripwire software can monitor. Directives control conditional processing of sets of rules in a policy file. During installation, the text policy file is encrypted/signed and renamed, and becomes the active policy file. The database file is an important component of Tripwire software. When first installed, Tripwire software uses the policy file rules to create the database file. The database file is a baseline "snapshot" of the system in a known secure state. Tripwire software compares this baseline against the current system to determine what changes have occurred. This is an integrity check. When you perform an integrity check, Tripwire software produces report files. Report files summarize any changes that violated the policy file rules during the integrity check. You can view the report file in a variety of formats, at varying levels of detail. The Tripwire configuration file stores system-specific information, such as the location of Tripwire data files. Tripwire software generates some of the configuration file information during installation. The system administrator can change parameters in the configuration file at any time. The configuration file variables POLFILE, DBFILE, REPORTFILE, SITEKEYFILE, and LOCALKEYFILE specify where the policy file, database file, report files, and site and local key files reside. These variables must be defined or the configuration file is invalid. If any of these variables are undefined, an error occurs on execution of Tripwire software and the program exits. Tripwire Help All Tripwire commands support the help arguments. Example: To get help with Create Configuration File mode, type: `twadmin --help --create-cfgfile` -? Display usage and version information --help Display all command modes --help all Display help for all command modes --help [mode] Display help for current command mode --version Display version information We recommend you read the Tripwire Release Notes and README file.