Table of Contents
The configuration file for 
    samhain is named 
    samhainrc by default. Also
    by default, it is placed in 
    /etc.
    (Name and location is configurable at compile time). The
    distribution package comes with a commented sample
    configuration file. The layout of the configuration file is
    described in more details in 
    Section 1 .
Events(e.g. unauthorized modifications of files monitored by samhain ) will generate messages of some severity. These messages will be logged to all logging facilities, whose threshold is equal to, or lower than, the severity of the message.
The following severity levels are defined:
| Level | Significance | 
|---|---|
| none | Keyword to switch off a looging facility (*). | 
| debug | Debugging-level messages. | 
| info | Informational message. | 
| notice | Normal conditions. | 
| warn | Warning conditions. | 
| mark | Timestamps. | 
| err | Error conditions. | 
| crit | Critical conditions. | 
| alert | Program startup/normal exit, or fatal error, causing abnormal program termination. | 
| inet | Incoming messages from clients (server only). | 
(*) the keyword 'none' can only be used as a threshold for logging facilities, to indicate that no messages shall be logged via that facility.
Most events (e.g. timestamps, internal errors, program startup/exit) have fixed severities. The following events have configurable severities: (*) the keyword 'none' can only be used as a threshold for logging facilities, to indicate that no messages shall be logged via that facility.
(server only) failure to resolve a client address (section [Misc], option SeverityLookup)
policy violations (for monitored files)
access errors for files
access errors for directories
obscure file names (with non-printable characters) and/or invalid UIDs/GIDs (no such user/group)
login/logout events (if samhain is configured to monitor them)
Severity levels for events (see Section 1.1 ) are set in the EventSeverity and (for login/logout events) the Utmp sections of the configuration file.
In the configuration file, these can be set as follows:
[EventSeverity] # # these are policies # SeverityReadOnly=crit SeverityLogFiles=crit SeverityGrowingLogs=warn SeverityIgnoreNone=crit SeverityIgnoreAll=info # # these are access errors # SeverityFiles=err SeverityDirs=err # # these are obscure file names # and/or invalid UIDs/GIDs (no such user/group) # SeverityNames=info # # This is the section for login/logout monitoring # [Utmp] SeverityLogin=notice SeverityLogout=notice # multiple logins by same user SeverityLoginMulti=err
Events of related type are grouped into classes. For each logging facility, it is possible to restrict logging to a subset of these classes (see Section 3 ). The available classes are:
| Class | Significance | 
|---|---|
| EVENT | Events to be reported (i.e. policy violations, login/logout). | 
| START | Startup/stop messages. | 
| STAMP | Timestamp (heartbeat) messages. | 
| LOGKEY | The key to verify the signed log file. | 
| ERROR | Error messages. | 
| OTHER | Everything else (e.g. informational messages). | 
| AUD | System calls (for debugging). | 
The aforementioned classes represent a new, simplified classification scheme since version 1.8.2. The previous scheme (listed below) will still work, and both can be mixed.
| Class | Significance | 
|---|---|
| AUD | System calls. | 
| RUN | Normal run messages (e.g. startup, exit, ...) | 
| STAMP | Timestamps and alike. | 
| FIL | Messages related to file integrity checking. | 
| TCP | Messages from the client/server subsystem. | 
| PANIC | Fatal errors, leading to program termination. | 
| ERR | Error messages (general). | 
| ENET | Error messages (network). | 
| EINPUT | Error messages (input, e.g. configuration file). | 
It is possible to customize the initial part (the 
        header of messages via the 
        MessageHeader=
        "format" directive. 
        Enclosing quotes are only required to protect
        leading/trailing space, and there is no need to escape
        quotes within the format string. The following
        placeholders are recognized: 
        
Severity of the message.
Timestamp of the message.
Class of the message.
Source file where the message originates from.
Line number (in the source file) where the message originates from.
An error code that may provide additional information in case of internal errors.
In the configuration file, these can be set as follows:
	  [Misc] 
	  # 
	  # This is the default without XML 
	  # 
	  MessageHeader="%S %T " 
	  # 
	  # Default for XML-style messages. 
	  # Note that quotes within the format strings are NOT escaped in any way. 
	  # 
	  # MessageHeader="<log sev="%S" tstamp="%T"