KEMBAR78
OSSEC Architecture and Installation Guide | PDF | Ip Address | Port (Computer Networking)
0% found this document useful (0 votes)
563 views25 pages

OSSEC Architecture and Installation Guide

OSSEC is composed of a central manager that collects information from connected agents, syslog sources, databases, and agentless devices. It stores logs, events, and integrity databases. Agents connect to the manager to collect and forward system information for analysis and correlation. OSSEC can monitor a variety of operating systems and devices through either installed agents or agentless integrity checks and log analysis.

Uploaded by

Aung Aung
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
563 views25 pages

OSSEC Architecture and Installation Guide

OSSEC is composed of a central manager that collects information from connected agents, syslog sources, databases, and agentless devices. It stores logs, events, and integrity databases. Agents connect to the manager to collect and forward system information for analysis and correlation. OSSEC can monitor a variety of operating systems and devices through either installed agents or agentless integrity checks and log analysis.

Uploaded by

Aung Aung
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
You are on page 1/ 25

OSSEC Architecture

OSSEC is composed of multiple pieces. It has a central manager for monitoring and receiving information
from agents, syslog, databases, and from agentless devices.

Manager (or Server)


The manager is the central piece of the OSSEC deployment. It stores the file integrity checking databases,
the logs, events, and system auditing entries. All the rules, decoders, and major configuration options are
stored centrally in the manager; making it easy to administer even a large number of agents.

Agents connect to the server on port 1514/udp. Communication to this port must be allowed for agents to
communicate with the server.

The manager may be called the OSSEC server, or even just server in this documentation.

Agents
The agent is a small program, or collection of programs, installed on the systems to be monitored. The agent
will collect information and forward it to the manager for analysis and correlation. Some information is
collected in real time, others periodically. It has a very small memory and CPU footprint by default, not
affecting the system’s usage.

Agent security: It runs with a low privilege user (generally created during the installation) and inside a
chroot jail isolated from the system. Most of the agent configuration can be pushed from the manager.

OSSEC can only be installed as an agent on Microsoft Windows platforms. These systems will require an
OSSEC server, running on Linux or another unix-like system.

Agentless
For systems that an agent cannot be installed on, the agentless support may allow integrity checks to be
performed. Agentless scans can be used to monitor firewalls, routers, and even Unix systems.

Virtualization/VMware
OSSEC allows you to install the agent on the guest operating systems. It may also be installed inside some
versions of VMWare ESX, but this may cause support issues. With the agent installed inside VMware ESX
you can get alerts about when a VM guest is being installed, removed, started, etc. It also monitors logins,
logouts and errors inside the ESX server. In addition to that, OSSEC performs the Center for Internet
Security (CIS) checks for VMware, alerting if there is any insecure configuration option enabled or any
other issue.

Firewalls, switches and routers


OSSEC can receive and analyze syslog events from a large variety of firewalls, switches and routers. It
supports all Cisco routers, Cisco PIX, Cisco FWSM, Cisco ASA, Juniper Routers, Netscreen firewall,
Checkpoint and many others.

Architecture
This diagram shows the central manager receiving events from the agents and system logs from remote
devices. When something is detected, active responses can be executed and the admin is notified.

Supported Systems
OSSEC supports the following operating systems and log formats.

Operating Systems
The following operating systems are supported by the OSSEC agent:

 GNU/Linux (all distributions, including RHEL, Ubuntu, Slackware, Debian, etc)


 Windows XP, 2003, Vista, 2008, 2012
 VMWare ESX 3.0,3.5 (including CIS checks)
 FreeBSD (all current versions)
 OpenBSD (all current versions)
 NetBSD (all current versions)
 Solaris 2.7, 2.8, 2.9 and 10
 AIX 5.2 and 5.3
 Mac OS X 10.x
 HP-UX 11

Devices supported via Syslog


These systems/devices are also supported via remote syslog:

 Cisco PIX, ASA and FWSM (all versions)


 Cisco IOS routers (all versions)
 Juniper Netscreen (all versions)
 SonicWall firewall (all versions)
 Checkpoint firewall (all versions)
 Cisco IOS IDS/IPS module (all versions)
 Sourcefire (Snort) IDS/IPS (all versions)
 Dragon NIDS (all versions)
 Checkpoint Smart Defense (all versions)
 McAfee VirusScan Enterprise (v8 and v8.5)
 Bluecoat proxy (all versions)
 Cisco VPN concentrators (all versions)
 VMWare ESXi 4.x

Devices and Operating Systems via Agentless


Using OSSEC agentless options, the following systems are also supported (for log analysis and file integrity
checking):

 Cisco PIX, ASA and FWSM (all versions)


 Cisco IOS routers (all versions)
 Juniper Netscreen (all versions)
 SonicWall firewall (all versions)
 Checkpoint firewall (all versions)
 All operating systems specified in the “operating systems” section

Installation
The best installation tutorial is available in the OSSEC book.

 Installations requirements

o Ubuntu

o RedHat

o Debian

 Manager/Agent Installation

 Manual Installation

 Windows Agent Installation

o Step 1: Opening the Agent Manager menu

o Step 2: Adding an Agent

o Step 3: Extracting a Key

o Step 4: The Windows Side

 Package Installation

o RPM Installation

o Deb Installation
 Compiling OSSEC for a Binary Installation

o Compiling OSSEC for install on a second server

o Installation of the binary OSSEC package

 Server Virtual Appliance Installation

o Overview:

o Accounts and passwords:

o Convert OVF to a VMWare image:

 Unattended Source Installation

 Compiling the OSSEC Windows Agent on Windows

o Requirements:

o Here are the steps:

 Compiling OSSEC 2.9 with MinGW:

 Compiling OSSEC 2.8.x with MinGW:

 Integration and Deployment with cfengine

o Prerequisites:

o Configuring the cfengine clients:

o Ok, so who cares?

o Configuring the OSSEC Server w/cfengine

 OSSEC Updates

Installations requirements
For UNIX systems, OSSEC only requires gnu make, gcc, and libc. OpenSSL is a suggested, but optional,
prerequisite. However, you always have the option to pre-compile it on one system and move the binaries to
the final box.

Ubuntu
On Ubuntu you will need the build-essential package in order to compile and install OSSEC.

To install the package run the following command.

# apt-get install build-essential


If database support is needed mysql-dev or postgresql-dev should be installed. Run the following command
to install these packages.

# apt-get install mysql-dev postgresql-dev

To use the SQLite features, the libsqlite3-dev package is necessary.

New in version 3.0.

# apt-get install libsqlite3-dev

RedHat
RedHat should have all packages needed by default, but if database support is needed the package mysql-
devel and/or postgresql-devel will need to be installed.

# yum install mysql-devel postgresql-devel

To use the SQLite features, the sqlite-devel package is necessary.

New in version 3.0.

# yum install sqlite-devel

Debian
Debian has replaced bash with dash, and this may cause issues during installation. Dash does not appear to
support all of the features available in other shells, and may display an error when trying to set the server’s
IP address on an agent system. The error can be ignored, but the server ip address will need to be set.

Do this by making sure something like the following information is in the agent’s ossec.conf:

<ossec_config>
<client>
<server-ip>SERVER'S IP</server-ip>
</client>

This can also be avoided by using bash to run install.sh:

# bash ./install.sh

Manager/Agent Installation
Installation of OSSEC HIDS is very simple, the install.sh shell script automating most of it. There are a few
questions to be answered before the installation will occur, one of the most important being which type of
installation is desired. It is important to choose the correct installation type: server, agent, local, or hybrid.
More information on them can be found on the OSSEC Architecture page.

In the following installation the commands follow the #. Everything else is either comments or output.

1. Download the latest version and verify its checksum.

On some systems, the command md5, sha1, or wget may not exist. Try md5sum, sha1sum or lynx
respectively instead.
wget may not be able to pull files from the OSSEC site. Use the -U flag to add a UserAgent, or obtain the
checksum file by some other manner.

# wget -U ossec https://bintray.com/artifact/download/ossec/ossec-hids/ossec-hids-


2.8.3.tar.gz
# wget -U ossec https://raw.githubusercontent.com/ossec/ossec-
docs/master/docs/whatsnew/checksums/2.8.3/ossec-hids-2.8.3.tar.gz.sha256
# cat ossec-hids-2.8.3.tar.gz.sha256
SHA256 (ossec-hids-2.8.3.tar.gz) =
917989e23330d18b0d900e8722392cdbe4f17364a547508742c0fd005a1df7dd
# sha256sum -c ossec-hids-2.8.3.tar.gz.sha256 ossec-hids-2.8.3.tar.gz
(SHA256) ossec-hids-2.8.3.tar.gz: OK

2. Extract the compressed package and run the install.sh script. It will guide you through the installation
and compile the source (not shown).
3. # tar -zxvf ossec-hids-*.tar.gz (or gunzip -d; tar -xvf)
4. # cd ossec-hids-*
5. # ./install.sh
6. The OSSEC manager listens on UDP port 1514. Any firewall sbetween the agents and the manager
will need to allow this traffic.
7. The server, agent, and hybrid installations will require additional configuration. More information
can be found on the Managing the agents page.
8. Start OSSEC HIDS by running the following command:
9. # /var/ossec/bin/ossec-control start

Manual Installation
OSSEC can also be installed in a more manual fashion. No modifications will be made to the ossec.conf file,
so it will have to be configured after installation. The ossec, ossecm and ossecr users will still be created
automatically.

After the source tarball is downloaded and extracted:

cd ossec-hids-*/src
make TARGET=<server|local|agent>
make install

Build options can still be passed to make (USE_ZEROMQ, USE_GEOIP, etc.).

Windows Agent Installation


OSSEC only supports Windows systems as agents, and they will require an OSSEC server to function.

Step 1: Opening the Agent Manager menu


The first step of this process is to get into the Agent Manager menu. From the ossec server, type the
following command:

/var/ossec/bin/manage_agents

The menu should look like this:

****************************************
* OSSEC HIDS v2.5-SNP-100809 Agent manager.*
* The following options are available:*
***************************************
(A)dd an agent (A).
(E)xtract key for an agent (E).
(L)ist already added agents (L).
(R)emove an agent (R).
(Q)uit.
Choose your action: A,E,L,R or Q:

Step 2: Adding an Agent


Adding an agent is the first thing that needs to be done. Choose action “A”.

The agent manager first asks for a name. This can be named anything.

Adding a new agent (use '\q' to return to the main menu).


Please provide the following: * A name for the new agent:

Next, it asks for the IP address of the windows client.

The IP Address of the new agent:

After that, it asks for a unique ID to assign to the client. The ID must be all numerical with a maximum of
eight digits. The agent manager also suggests ID’s for new agents.

An ID for the new agent[001]:

Lastly, it asks for confirmation of all the information provided. Then it appends all of the agent information
to /var/ossec/etc/client.keys and returns to the main menu.

Step 3: Extracting a Key


Now, the client key needs to be extracted. From the main menu, choose action “E”. A list of agents will be
displayed:

Available agents: ID: 001, Name: agent1, IP: 10.10.50.2


Provide the ID of the agent to extract the key (or '\q' to quit):

Enter the full ID of the agent to extract the key for. It will display the entire key. Copy that to the clipboard,
for it will be needed later.

Agent key information for '001'


is:MDAyIGFnZW50MSAxOTIuMTY4LjIuMC8yNCBlNmY3N2RiMTdmMTJjZGRmZjg5YzA4ZDk5m

Step 4: The Windows Side


Next up, download the executable named Agent Windows from https://ossec.github.io/downloads.html. Run
through the install wizard with all defaults. It should launch the Ossec Agent Manager when it’s done. The
Ossec Agent Manager looks like this:

Enter the IP address of your ossec server in the first text field, and enter the extracted key that was copied to
the clipboard earlier to the second textfield. Finally, click on the manage tab and hit restart.
Package Installation
The OSSEC project has made RPM and deb packages available. Links to the packages can be found on the
OSSEC download page

RPM Installation
OSSEC’s RPMs are made available by AtomiCorp.

The RPMs can be installed by adding the AtomiCorp yum repository:

# wget -q -O - https://updates.atomicorp.com/installers/atomic |sh

Next use yum to install the specific packages. For an OSSEC server run:

# yum install ossec-hids ossec-hids-server

And for an agent run:

# yum install ossec-hids ossec-hids-agent

Deb Installation
OSSEC’s deb packages are available in the Wazuh repository.

Install the apt-get repository key:

# apt-key adv --fetch-keys http://ossec.wazuh.com/repos/apt/conf/ossec-key.gpg.key

Add the repository for Debian (available distributions are Sid, Jessie and Wheezy):

# echo 'deb http://ossec.wazuh.com/repos/apt/debian wheezy main' >>


/etc/apt/sources.list

Or add the repository for Ubuntu (available distributions are Precise, Trusty and Utopic):

# echo 'deb http://ossec.wazuh.com/repos/apt/ubuntu precise main' >>


/etc/apt/sources.list

Update the repository:

Install OSSEC HIDS server/manager:

# apt-get install ossec-hids

Or install OSSEC HIDS agent:

# apt-get install ossec-hids-agent

Compiling OSSEC for a Binary Installation


OSSEC is typically compiled on each system it is installed on, but this may not always be easy. To help in
these cases there are a few methods of binary installation available. OSSEC can be compiled on one system,
and copied to the destination systems. There ar RPM and deb packages available.

OSSEC has very limited cross compiling facilities. Windows binaries can be built on Linux systems, but
binaries for other systems should be built on a system of the same OS and CPU platform.

Compiling OSSEC for install on a second server


First download the OSSEC package corresponding to the version you want to install and unpack it (on the
system with a compiler).

# wget -U ossec http://www.ossec.net/files/ossec-hids-2.8.1.tar.gz


# tar -zxvf ossec-hids-latest.tar.gz

Enter in the source directory of the downloaded package, and configure OSSEC to build the agent version.
The make commands should compile the correct binaries.

# cd ossec-*/src
# make setagent
# make all
# make build

Modify ossec-hids-*/etc/preloaded-vars.conf to set BINARY_INSTALL to yes.

# echo "USER_BINARYINSTALL=\"y\"" >> ossec-hids*/etc/preloaded-vars.conf

Finally create an OSSEC package.

# tar -cvf ossec-binary.tar ossec-hids*

Installation of the binary OSSEC package


On the target system (that does not have a C compiler) download your ossec-binary.tar created in the steps
above.

Complete the installation by unarchiving the binary package and running ./install.sh.

# tar xfv ossec-binary.tar


# cd ossec-*
# ./install.sh

After following the installation prompts the install will be complete.

Server Virtual Appliance Installation


Overview:
The OSSEC virtual appliance is a virtual system in the Open Virtualized Format (OVF). It contains an
OSSEC 2.7 server installation and the WebUI (0.8 Beta).

Accounts and passwords:


The default password for all accounts on the system is _0ssec_. The username from the WebUI is user, and
for phpMyAdmin it is root.

Convert OVF to a VMWare image:


Some VMWare desktop environments may not support the OVF images natively, for those systems
VMWare created the ovftool. Download the ovftool from VMWare’s site (registration required).

Convert the file using the following procedure:

# tar zxvf ossec_virtual_appliance.tar.gz


# cd ossec_virtual_appliance
# ovftool ossec.ovf ossec.vmx

Unattended Source Installation


OSSEC has the capability to be compiled and installed without the interactivity of install.sh. The install
script can collect the answers to its questions from the etc/preloaded-vars.conf configuration file.

Most of the questions asked by the installer are present in the configuration file, along with the default
answers. Uncommenting each variable will allow the script to know the answer. Any changes from the
default install should be made in the configuration file.

If USER_NO_STOP="y" is not set, install.sh may prompt for confirmation.

Example preloaded-vars.conf:

# preloaded-vars.conf, Daniel B. Cid (dcid @ ossec.net).


#
# Use this file to customize your installations.
# It will make the install.sh script pre-load some
# specific options to make it run automatically
# or with less questions.

# PLEASE NOTE:
# When we use "n" or "y" in here, it should be changed
# to "n" or "y" in the language your are doing the
# installation. For example, in portuguese it would
# be "s" or "n".

# USER_LANGUAGE defines to language to be used.


# It can be "en", "br", "tr", "it", "de" or "pl".
# In case of an invalid language, it will default
# to English "en"
#USER_LANGUAGE="en" # For english
#USER_LANGUAGE="br" # For portuguese

# If USER_NO_STOP is set to anything, the confirmation


# messages are not going to be asked.
#USER_NO_STOP="y"

# USER_INSTALL_TYPE defines the installation type to


# be used during install. It can only be "local",
# "agent" or "server".
#USER_INSTALL_TYPE="local"
#USER_INSTALL_TYPE="agent"
#USER_INSTALL_TYPE="server"

# USER_DIR defines the location to install ossec


#USER_DIR="/var/ossec"

# If USER_DELETE_DIR is set to "y", the directory


# to install OSSEC will be removed if present.
#USER_DELETE_DIR="y"

# If USER_ENABLE_ACTIVE_RESPONSE is set to "n",


# active response will be disabled.
#USER_ENABLE_ACTIVE_RESPONSE="y"

# If USER_ENABLE_SYSCHECK is set to "y",


# syscheck will be enabled. Set to "n" to
# disable it.
#USER_ENABLE_SYSCHECK="y"

# If USER_ENABLE_ROOTCHECK is set to "y",


# rootcheck will be enabled. Set to "n" to
# disable it.
#USER_ENABLE_ROOTCHECK="y"

# If USER_UPDATE is set to anything, the update


# installation will be done.
#USER_UPDATE="y"

# If USER_UPDATE_RULES is set to anything, the


# rules will also be updated.
#USER_UPDATE_RULES="y"

# If USER_BINARYINSTALL is set, the installation


# is not going to compile the code, but use the
# binaries from ./bin/
#USER_BINARYINSTALL="x"

### Agent Installation variables. ###

# Specifies the IP address or hostname of the


# ossec server. Only used on agent installations.
# Choose only one, not both.
# USER_AGENT_SERVER_IP="1.2.3.4"
# USER_AGENT_SERVER_NAME

# USER_AGENT_CONFIG_PROFILE specifies the agent's config profile


# name. This is used to create agent.conf configuration profiles
# for this particular profile name. Only used on agent installations.
# Can be any string. E.g. LinuxDBServer or WindowsDomainController
#USER_AGENT_CONFIG_PROFILE="generic"

### Server/Local Installation variables. ###

# USER_ENABLE_EMAIL enables or disables email alerting.


#USER_ENABLE_EMAIL="y"

# USER_EMAIL_ADDRESS defines the destination e-mail of the alerts.


#USER_EMAIL_ADDRESS="dcid@test.ossec.net"
# USER_EMAIL_SMTP defines the SMTP server to send the e-mails.
#USER_EMAIL_SMTP="test.ossec.net"

# USER_ENABLE_SYSLOG enables or disables remote syslog.


#USER_ENABLE_SYSLOG="y"

# USER_ENABLE_FIREWALL_RESPONSE enables or disables


# the firewall response.
#USER_ENABLE_FIREWALL_RESPONSE="y"

# Enable PF firewall (OpenBSD and FreeBSD only)


#USER_ENABLE_PF="y"

# PF table to use (OpenBSD and FreeBSD only).


#USER_PF_TABLE="ossec_fwtable"

# USER_WHITE_LIST is a list of IPs or networks


# that are going to be set to never be blocked.
#USER_WHITE_LIST="192.168.2.1 192.168.1.0/24"

#### exit ? ###

Compiling the OSSEC Windows Agent on


Windows
As of 2.9 this is no longer supported. The Windows agent can be built on Linux systems. Patches to update
the Windows compilation support are very welcome.

Originally posted Compiling the OSSEC Windows Agent on Windows by mstarks, duplicated here with
permission.

Most people that use the OSSEC Windows agent download a pre-compiled copy from the OSSEC site.
While that is a good option for many individual users, it may not suit those with more specific needs and/or
those in enterprise environments. Users who fall into those categories could benefit from customizing the
agent and maintaining internal builds in order to suit their individual needs.

There are already instructions on how to compile the Windows agent on Linux, but ironically the process
doesn’t work so well on Windows. I had a need to make this work on Windows, so I thought I would share
the process with you.

Requirements:
 The Nullsoft Scriptable Install System (NSIS)
 The Minimalist GNU for Windows (MinGW) compiler
 My batch file. Simply rename from gen_win.txt to gen_win.cmd.
 7-Zip for Windows
 The public domain Unix2DOS utility
 The latest OSSEC for Unix/Linux (this contains the Windows source code)
Here are the steps:
1. Download and install the required programs. Be sure to pay special attention to the steps for properly
installing and configuring MinGW, particularly the part about modifying the PATH environment
variable.
2. Next, we.re going to extract OSSEC using 7-Zip. To do so, simply right-click on the file and select
7-Zip, extract to “folder name.tar,” where folder name is the name of the package. This
decompresses the archive. Navigate within that folder and repeat this step to untar the archive. At
this point, you should see all of the files in the package.
3. Place gen_win.txt in the src\win32 folder and rename the extension to .cmd.
4. Download Unix2DOS and place it in the src\win32 folder
5. Open a command prompt. Navigate to src\win32, make any desired customizations, and execute
gen_win.cmd. This should gather all of the required files and place them in src\win-pkg.
6. Next, we compile the Windows agent by navigating to src\win-pkg and executing make.bat (I
assume you have the chops to know how to change directories :) ).
7. Now we have all of the files we need but no way to effectively install it. To generate the installer,
simply execute the NSIS compiler like so: "c:\Program Files\NSIS\makensis.exe" ossec-
installer.nsi

If you see no errors and a binary named ossec-win32-agent.exe, everything was successful. Congratulations,
you now have a custom-made version of OSSEC!

OSSEC’s Windows agent is compiled using MinGW

This documentation assumes you have MinGW installed, and it is usable. An example of installing MinGW
on CentOS is available here.

It has always been a pain to generate snapshots for Windows because it required me to open up my
Windows VM (slow), push the code there, compile, etc. Well, until this week when I started to play with
MinGW cross-compilation feature to completely build an Windows agent from Linux.

How it works? First, you need to install MinGW and nsis (to build the installer). For OpenSSL support, an
OpenSSL MinGW package will also be necessary.

After that, download the source and generate the Windows package directory (replace 2.6 with the latest
version or download the latest source from the github repository):

On some systems, the command md5, sha1, or wget may not exist. Try md5sum, sha1sum or lynx
respectively instead.

wget may not be able to pull files from the OSSEC site. Use the -U flag to add a UserAgent, or obtain the
checksum file by some other manner.

# wget -U ossec https://bintray.com/artifact/download/ossec/ossec-hids/ossec-hids-


2.8.3.tar.gz
# wget -U ossec https://raw.githubusercontent.com/ossec/ossec-
docs/master/docs/whatsnew/checksums/2.8.3/ossec-hids-2.8.3.tar.gz.sha256
# cat ossec-hids-2.8.3.tar.gz.sha256
SHA256 (ossec-hids-2.8.3.tar.gz) =
917989e23330d18b0d900e8722392cdbe4f17364a547508742c0fd005a1df7dd
# sha256sum -c ossec-hids-2.8.3.tar.gz.sha256 ossec-hids-2.8.3.tar.gz
(SHA256) ossec-hids-2.8.3.tar.gz: OK

Compiling OSSEC 2.9 with MinGW:


Change directory to the src directory:

# cd ossec-hids-2.9.0/src

Now run make TARGET=winagent:

# make TARGET=winagent

This should produce a good amount of compilation output that ends with:

Output: "ossec-win32-agent.exe"
Install: 7 pages (448 bytes), 3 sections (3144 bytes), 769 instructions (21532 bytes),
318 strings (32350 bytes), 1 language table (346 bytes).
Uninstall: 5 pages (320 bytes),
1 section (1048 bytes), 350 instructions (9800 bytes), 184 strings (3360 bytes), 1
language table (290 bytes).
Datablock optimizer saved 100205 bytes (~8.1%).

Using zlib compression.

EXE header size: 57856 / 56320 bytes


Install code: 14832 / 58196 bytes
Install data: 1045670 / 3116385 bytes
Uninstall code+data: 21058 / 21474 bytes
CRC (0x239C5E6F): 4 / 4 bytes

Total size: 1139420 / 3252379 bytes (35.0%)


make settings
make[1]: Entering directory `/home/ddp/src/projects/git/github/ddpbsd/ossec-hids/src'

General settings:
TARGET: winagent
V:
DEBUG:
DEBUGAD
PREFIX: /var/ossec
MAXAGENTS: 2048
DATABASE:
ONEWAY: no
CLEANFULL: no
User settings:
OSSEC_GROUP: ossec
OSSEC_USER: ossec
OSSEC_USER_MAIL: ossecm
OSSEC_USER_REM: ossecr
Lua settings:
LUA_PLAT: posix
USE settings:
USE_ZEROMQ: no
USE_GEOIP: no
USE_PRELUDE: no
USE_OPENSSL: no
USE_INOTIFY: no
Mysql settings:
includes:
libs:
Pgsql settings:
includes:
libs:
Defines:
-DMAX_AGENTS=2048 -DOSSECHIDS -DDEFAULTDIR="/var/ossec" -DUSER="ossec"
-DREMUSER="ossecr" -DGROUPGLOBAL="ossec" -DMAILUSER="ossecm" -DLinux
Compiler:
CFLAGS -O2 -DMAX_AGENTS=2048 -DOSSECHIDS -DDEFAULTDIR="/var/ossec"
-DUSER="ossec" -DREMUSER="ossecr" -DGROUPGLOBAL="ossec" -DMAILUSER="ossecm" -DLinux
-Wall -Wextra -I./ -I./headers/
LDFLAGS -lm
CC gcc
MAKE make
make[1]: Leaving directory `/home/ddp/src/projects/git/github/ddpbsd/ossec-hids/src'

Done building winagent

The final output will be saved to ./win32/ossec-win32-agent.exe.

Compiling OSSEC 2.8.x with MinGW:


Generate the Windows package directory:

# cd ossec-hids-2.8.3/src/win32
# ./gen-win.sh

Now, you will have the win-pkg directory under src. Just go there and run make.sh. Your Windows agent
package should be created in a few minutes:

The make.sh script may require modification depending on the Linux distribution used.

# cd ../win-pkg
# sh ./make.sh

You will see the following in the screen:

Making windows agent


rootcheck/win-common.c: In function "__os_winreg_querykey":
rootcheck/win-common.c:279: warning: pointer targets in passing argument 7 of
"RegEnumValueA" differ in signedness
win-registry.c: In function "os_winreg_querykey":
...

Output: "ossec-win32-agent.exe"
Install: 7 pages (448 bytes), 3 sections (3144 bytes), 379 instructions (10612 bytes),
247 strings (42580 bytes), 1 language table (346 bytes).
Uninstall: 5 pages (320 bytes),
1 section (1048 bytes), 301 instructions (8428 bytes), 166 strings (2646 bytes), 1
language table (290 bytes).
Datablock optimizer saved 8371 bytes (~0.7%).

Which means that your agent executable ossec-win32-agent.exe has been created properly.

Integration and Deployment with cfengine


I recently required a larger deployment of OSSEC-HIDS without too much manual intervention. Almost
every OSSEC-HIDS tutorial I’ve across says this is possible, yet I was unable to find a tutorial
demonstrating it. So, in the spirit of open source, I’m contributing a brief overview.

Prerequisites:
In order to facilitate the key request, I chose to generate a file with the relevant information and copy it back
to my cfmaster server. I developed the following tutorial to demonstrate a cfengine copy back scenario:
Copy Back with cfengine.
Configuring the cfengine clients:
I added a group to my cfagent.conf for my ossec server named: hg_ossec_server (host group). I then
created an ossec-hids.cf containing the following:

 control

My control sections sets up the variables I’ll be using in the rest of the file.

control:
any::
ossec_key_dir = (/usr/local/cfkeys/ossec)
ossec_req_dir = ( $(util_updir)/ossec )

 package

I’m using yum to automatically install OSSEC-HIDS from my local RPM Repository.

packages:
!hg_ossec_server::
ossec-hids action=install
ossec-hids-client action=install

 links

The Links section just links ossec-agent.conf to ossec.conf on the clients.

links:
!hg_ossec_server::
/var/ossec/etc/ossec.conf -> /var/ossec/etc/ossec-agent.conf

 copy

I manage the ossec-agent.conf in cfengine, because my cfengine configurations are all stored in a
subversion repository. The first stanza in copy just pushes the most recent copy of the ossec-agent.conf
file to my network, setting the dynamic class dc_restart_ossec if the copy occurs.

copy:
!hg_ossec_server::
$(distribute)/ossec-agent.conf dest=/var/ossec/etc/ossec-agent.conf
server=$(policyhost)
mode=640
group=ossec
type=sum
define=dc_restart_ossec

This second stanza in the copy section copies a file from our ossec key directory to the client.keys file on the
client. This copy only happens if the two files are different. It also sets dc_restart_ossec if the copy
occurs.

$(ossec_key_dir)/$(host).ossec dest=/var/ossec/etc/client.keys
server=$(policyhost)
mode=640
group=ossec
type=sum
define=dc_restart_ossec

 processes
My processes block checks to ensure that OSSEC-HIDS is running the correct daemons.

processes:
!hg_ossec_server::
"ossec-agentd" elsedefine=dc_restart_ossec
``hg_ossec_server``::
"ossec-remoted" elsedefine=dc_restart_ossec

 shellcommands

This section is where the certificate request occurs through some devious mechanisms I designed for no
other reason than to amuse myself. Hopefully, it amuses others as well. The first thing it does is issue a
command that echo’s the client eth0 ipv4 address to a file named ‘’host.ossec’’ in the ossec request directory
I defined. The hg_ossec_server class will use this to generate a cert to place in the aforementioned copy
block.

shellcommands:
!hg_ossec_server::
"/usr/bin/ssh util@$(policyhost) -i $(util_privkey) 'echo $(global.ipv4[eth0]) >
$(ossec_req_dir)/$(host).ossec'"

The last statement checks to see if anyone defined dc_restart_ossec, and restart ossec-hids if it was
defined.

dc_restart_ossec::
"/sbin/service ossec-hids restart"

Ok, so who cares?


Well, now, our clients are setup to install, configure, and run OSSEC-HIDS as well as issuing a request for
their certificate. However, the certificate directory on the server is empty and so none of them will actually
run. This is a problem.

Configuring the OSSEC Server w/cfengine


The cfengine part of this was a pain for me because of the order of the actions I had defined and the extent
of work I had done incorrectly in the past. I could have figured out an interesting way to handle this, but I
didn’t want to scrap my entire cfengine config and start from scratch. So I created a perl script that allowed
me to use the manage_agents script without interaction. It does require the Expect.pm & Regexp::Common
from CPAN, but is otherwise stock Perl 5.8.x. I also wrote a shell script wrapper to handle running the perl
script and culminating the results. I saved these two scripts in /root/security, so if you put them
elsewhere, make sure to update the shell script wrapper.

The scripts for managing keys can be downloaded here

The cfengine bit was really simple, it just had to call my wrapper shell script and set the class. I did this with
a control block:

control:
hg_ossec_server::
AddClasses = ( ExecResult(/root/security/ossec-scan.sh) )

The combination of the two scripts and this one line in the cfengine configuration handle creating, removing,
and exporting the keys, as well as configuring the dc_restart_ossec class if there have been changes.
OSSEC Updates
Updating OSSEC is as easy as it can get. Just download the latest package and follow the installation
instructions as usual. It will detect that you already have it installed and ask:

- You already have OSSEC installed. Do you want to update it? (y/n): y

Just answer yes to this question and the script will update the OSSEC binaries. local_rules.xml and
local_decoder.xml will not be modified during this upgrade.

The script will also prompt for an answer to the following question:

- Do you want to update the rules? (y/n): y

Answering yes to this question updates the <rules> section of the system’s ossec.conf.

Agents
There are two types of agents within OSSEC: installable agents and agentless agents. Installable agents are
installed on hosts, and they report back to a central OSSEC server via the OSSEC encrypted message
protocol. Agentless agents require no installation on remote hosts. They are processes initiated from the
OSSEC manager, which gather information from remote systems, and use any RPC method (e.g. ssh, snmp
rdp, wmi).

Agent

 Communication between agents and the OSSEC server

 Managing Agents

o manage_agents on the OSSEC server

o Extracting the key for an agent

o Removing an agent

o manage_agents on OSSEC agents

 Agent systems behind NAT or with dynamic IPs (DHCP)

o DHCP Example

o NAT Example

 Adding an agent with ossec-authd

o ossec-authd

o agent-auth

 Centralized agent configuration

o Create agent configuration


o Restart the agent

Agentless

 Agentless Monitoring

o Agentless configuration options

o Getting started with agentless

o Configuring agentless

o Running the completed setup

o Alerts

 Writing Agentless Scripts

o Agentless Script Types

o Agentless Script: ssh_integrity_check_linux

o Modifying to make own Agentless Script: ssh_dmz_linux

Communication between agents and the OSSEC


server
Communication between agents and the OSSEC server generally occurs on port 1514/udp in secure mode. If
using the syslog mode for ossec-remoted, then port 514 is the default (both UDP and TCP are supported).
These ports are configurable in the remote section of the ossec.conf

The secure connection method is generally preferred over syslog. Also, an outside syslog daemon (like
rsyslog or syslog-ng) may be used instead of the syslog support in ossec-remoted.

Managing Agents
To add an agent to an OSSEC manager with manage_agents you need to follow the steps below.

1. Run manage_agents on the OSSEC server.


2. Add an agent.
3. Extract the key for the agent.
4. Copy that key to the agent.
5. Run manage_agents on the agent.
6. Import the key copied from the manager.
7. Restart the manager’s OSSEC processes.
8. Start the agent.

manage_agents on the OSSEC server


The server version of manage_agents provides an interface to:
 add an OSSEC agent to the OSSEC server
 extract the key for an agent already added to the OSSEC server
 remove an agent from the OSSEC server
 list all agents already added to the OSSEC server.

Running manage_agents and start screen

manage_agents should be run as a user with the appropriate privileges (e.g. root).

Run manage_agents:

# /var/ossec/bin/manage_agents

The manage_agents menu:

****************************************
* OSSEC HIDS v2.5-SNP-100809 Agent manager. *
* The following options are available: *
****************************************
(A)dd an agent (A).
(E)xtract key for an agent (E).
(L)ist already added agents (L).
(R)emove an agent (R).
(Q)uit.
Choose your action: A,E,L,R or Q:

Typing the appropriate letter and hitting enter will initiate that function.

Adding an agent

To add an agent type a in the start screen:

Choose your action: A,E,L,R or Q: a

You are then prompted to provide a name for the new agent. This can be the hostname or another string to
identify the system. In this example the agent name will be agent1.

- Adding a new agent (use '\q' to return to the main menu).


Please provide the following:
* A name for the new agent: agent1

After that you have to specify the IP address for the agent. This can either be a single IP address (e.g.
192.168.1.25), a range of IPs (e.g. 192.168.2.0/24), or any. Using a network range or any is preferable when
the IP of the agent may change frequently (DHCP), or multiple systems will appear to come from the same
IP address (NAT).

* The IP Address of the new agent: 192.168.2.0/24

If you use a specific IP address it must be unique. Duplicate IP addresses will cause issues. Multiple
systems can use the same IP range or any.

The last information you will be asked for is the ID you want to assign to the agent. manage_agents will
suggest a value for the ID. This value should be the lowest positive number that is not already assigned to
another agent. The ID 000 is assigned to the OSSEC server. To accept the suggestion, simply press ENTER.
To choose another value, type it in and press ENTER.

* An ID for the new agent[001]:


As the final step in creating an agent, you have to confirm adding the agent:

Agent information:
ID:002
Name:agent1
IP Address:192.168.2.0/24

Confirm adding it?(y/n): y


Agent added.

After that manage_agents appends the agent information to /var/ossec/etc/client.keys and goes back to the
start screen.

If this is the first agent added to this server, the server’s OSSEC processes should be restarted using
/var/ossec/bin/ossec-control restart.

Extracting the key for an agent


After adding an agent, a key is created. This key must be copied to the agent. To extract the key, use the e
option in the manage_agents start screen. You will be given a list of all agents on the server. To extract the
key for an agent, simply type in the agent ID. It is important to note that you have to enter all digits of the
ID.

Choose your action: A,E,L,R or Q: e

Available agents:
ID: 001, Name: agent1, IP: 192.168.2.0/24
Provide the ID of the agent to extract the key (or '\q' to quit): 001

Agent key information for '001' is:


MDAyIGFnZW50MSAxOTIuMTY4LjIuMC8yNCBlNmY3N2RiMTdmMTJjZGRmZjg5YzA4ZDk5m

** Press ENTER to return to the main menu.

The key is encoded in the string (shortened for this example)


MDAyIGFnZW50MSAxOTIuMTY4LjIuMC8yNCBlNmY3N2RiMTdmMTJjZGRmZjg5YzA4ZDk5Mm and includes
information about the agent. This string can be added to the agent through the agent version of
manage_agents.

Removing an agent
If you want to remove an OSSEC agent from the server, use the r option in the manage_agents start screen.
You will be given a list of all agents already added to the server. To remove an agent, simply type in the ID
of the agent, press enter, and finally confirm the deletion. It is important to note that you have to enter all
digits of the ID.

Choose your action: A,E,L,R or Q: r

Available agents:
ID: 001, Name: agent1, IP: 192.168.2.0/24
Provide the ID of the agent to be removed (or '\q' to quit): 001
Confirm deleting it?(y/n): y
Agent '001' removed.

manage_agents then invalidates the agent information in /var/ossec/etc/client.keys. Only the values
for ID and the key are kept to avoid conflicts when adding agents. The deleted agent can no longer
communicate with the OSSEC server.
manage_agents on OSSEC agents
The agent version provides an interface for importing authentication keys.

****************************************
* OSSEC HIDS v2.5-SNP-100809 Agent manager. *
* The following options are available: *
****************************************
(I)mport key from the server (I).
(Q)uit.
Choose your action: I or Q: i

* Provide the Key generated by the server.


* The best approach is to cut and paste it.
*** OBS: Do not include spaces or new lines.

Paste it here (or '\q' to quit): [key extracted via manage_agents on the server]

Agent information:
ID:001
Name:agent1
IP Address:192.168.2.0/24

Confirm adding it?(y/n): y


Added.
** Press ENTER to return to the main menu.

For the changes to be in effect you have to restart the server and start the agent.

Agent systems behind NAT or with dynamic IPs


(DHCP)
If you want to install the agent on systems without a static IP address or behind a NAT device, you need to
configure the agent using a CIDR address or the ip address of any.

DHCP Example
To add an agent that can receive any IP address in the 192.168.2.0/24 network, just provide the IP address of
the agent as 192.168.2.0/24. Example (taken from manage_agents):

Please provide the following:


* A name for the new agent: test
* The IP Address of the new agent: 192.168.2.0/24

NAT Example
The same applies to systems behind a NAT device. The OSSEC server will see all agents behind the NAT as
if they have the same IP address.

For example, you have systems 192.168.1.2, 192.168.1.3 and 192.168.1.4 behind a nat server that connects
to network 10.1.1.0/24 with the ossec server on it.

In this case, you need to config the agents as if their IP was 10.1.1.0/24, because this is the IP that the server
is seeing (not their original IP). Using any instead of an IP address or range is also a valid option, allowing
the agent to connect from any IP address.
On the manage_agents tool, add each one of those agents on the server using the following format:

Please provide the following:


* A name for the new agent: agent-1
* The IP Address of the new agent: 10.1.1.0/24
Please provide the following:
* A name for the new agent: agent-2
* The IP Address of the new agent: any

Make sure to use one separate key for each agent.

Adding an agent with ossec-authd


It is possible to add a key to a system via an automated method. ossec-authd and agent-auth provide this
functionality.

ossec-authd
ossec-authd will run on the server adding agents and distributing authentication keys.

There is currently no authentication, so any host that can connect to the port ossec-authd listens to can obtain
an OSSEC agent key. It is recommended that the OSSEC manager’s firewall be used to help limit
connections.

Run ossec-authd, listening on port 1515:

/var/ossec/bin/ossec-authd -p 1515

agent-auth
agent-auth will connect to an ossec-authd instance to receive, and install an agent key.

Run agent-auth connecting to the manager on IP 192.168.1.12 port 1515:

/var/ossec/bin/agent-auth -m 192.168.1.12 -p 1515

Centralized agent configuration


If you ever wanted to be able to configure your agents remotely, you will be happy to know that starting on
version 2.1 you will be able to do so. We allow centralized configuration for file integrity checking
(syscheckd), rootkit detection (rootcheck) and log analysis.

This is how it works.

Create agent configuration


First Create the file /var/ossec/etc/shared/agent.conf.

Inside the file you can configure the agent just as you would normally at ossec.conf

<agent_config>
<localfile>
<location>/var/log/my.log</location>
<log_format>syslog</log_format>
</localfile>
</agent_config>

But you have a few more options. You can restrict the config by agent name, operating system, or profile:

<agent_config name="agent1">
<localfile>
<location>/var/log/my.log</location>
<log_format>syslog</log_format>
</localfile>
</agent_config>

<agent_config os="Linux">
<localfile>
<location>/var/log/my.log2</location>
<log_format>syslog</log_format>
</localfile>
</agent_config>

<agent_config os="Windows">
<localfile>
<location>C:\myapp\my.log</location>
<log_format>syslog</log_format>
</localfile>
</agent_config>

And only the proper agent will read them, giving us great granularity to push the configuration to all your
agents.

After you configured, the manager will push it to the agents. Note that it can take a while for it to complete
(since the manager caches the shared files and only re-reads them every few hours). If you restart the
manager the configuration will be pushed much quicker.

Restart the agent


Once the configuration file is pushed, you can run the command agent_control to see if the agent received
the config and restart the agent remotely.

# md5sum /var/ossec/etc/shared/agent.conf
MD5 (/var/ossec/etc/shared/agent.conf) = ee1882236893df851bd9e4842007e7e7
# /var/ossec/bin/agent_control -i 200

OSSEC HIDS agent_control. Agent information:


Agent ID: 200
Agent Name: ourhome
IP address: 192.168.0.0/16
Status: Active

Operating system: Linux ourhome 2.6.24-23-generic #1 SMP Mon Jan 26 00..


Client version: OSSEC HIDS v2.1 / ee1882236893df851bd9e4842007e7e7
Last keep alive: Tue Jun 30 08:29:17 2009

Syscheck last started at: Tue Jun 30 04:29:32 2009


Rootcheck last started at: Tue Jun 30 06:03:08 2009

When the agent received the configuration, the “Client Version” field will have the md5sum of the
agent.conf file.

Linux systems generally use md5sum, but other systems may use md5 as the name of the application to check
the hash of the file.
To restart the agent:

# /var/ossec/bin/agent_control -R 200 (where 200 is the agent id)

OSSEC HIDS agent_control: Restarting agent: 200

You might also like