# # Accepted parameters for 'rpmbuild': # # --with tests - make tests before building Summary: File integrity and host-based IDS Name: @install_name@ Version: @VERSION@ Release: 1 License: GPL Group: System Environment/Base Source: samhain-%{version}.tar.gz BuildRoot: %{_tmppath}/samhain-%{version}-root Packager: Andre Oliveira da Costa Provides: %{name} # dummy (fix configure warning) # datarootdir = @datarootdir@ # no quotes here - aparently will be expanded literally %define withpwd_prg x@clmytclient@ %define withstg_prg x@stegin_prg@ # disable automatic stripping of binaries upon installation %define __spec_install_post %{nil} # required because DeadRat wants to package some debug info otherwise # (this debug info would be created by debug_install_post called # from spec_install_post) %define debug_package %{nil} # Use internal dependency generator rather than external helpers? %define _use_internal_dependency_generator 0 %description @install_name@ is an open source file integrity and host-based intrusion detection system for Linux and Unix. It can run as a daemon process, and and thus can remember file changes -- contrary to a tool that runs from cron, if a file is modified you will get only one report, while subsequent checks of that file will ignore the modification as it is already reported (unless the file is modified again). @install_name@ can optionally be used as client/server system to provide centralized monitoring for multiple host. Logging to a (MySQL or PostgreSQL) database is supported. NOTE: for security reasons, if you distribute binary executables to third parties you should point out the use of the --add-key option to modify the key material within the executable. This spec file is intended to facilitate installation on YOUR system. If you use this spec file to build a SRPM for distribution to third parties, make sure to remove the --enable-base configure option below. %prep %setup -q -n samhain-%{version} %build %if %{?_with_tests:1}%{!?_with_tests:0} # test installation (test #7 is only included if --with gpg has been # specified) for i in `seq 6` %{?_with_gpg:7}; do ./test/test.sh $i; done %endif # # configure with the user-supplied arguments to './configure' # ./configure @mydefargs@ make %install rm -rf ${RPM_BUILD_ROOT} # sstrip shouldn't be used since binaries will be stripped later ## cat << EOF > sstrip ## #!/bin/sh ## echo "*** SSTRIP DISABLED ***" ## EOF make DESTDIR=${RPM_BUILD_ROOT} install # copy script files to /var/lib/samhain so that we can use them right # after the package is installed # install -m 700 samhain-install.sh init/samhain.startLinux init/samhain.startLSB ${RPM_BUILD_ROOT}@mydataroot@ # # file list (helpful advice from Lars Kellogg-Stedman) # echo "@sbindir@/@install_name@" > sh_file_list find %{buildroot}/lib/modules \! -type d -print | \ sed 's,%{buildroot},,' >> sh_file_list %clean rm -rf ${RPM_BUILD_ROOT} %post if test "x@sh_lkm@" = x; then : else if test -f /sbin/depmod; then /sbin/depmod -a fi fi if [ "$1" -ge 1 ]; then # Activate boot-time start up cd @mydataroot@ /bin/sh ./samhain-install.sh --verbose install-boot rm -f ./samhain.startLSB rm -f ./samhain.startLinux if [ -f @sbindir@/@install_name@_stealth ]; then rm -f samhain-install.sh fi shkeep=yes if test x"$shkeep" = xno; then rm -f ./samhain-install.sh rm -f @sbindir@/@install_name@_stealth fi fi if [ "$1" = 1 ]; then if test -f /usr/lib/lsb/install_initd; then /usr/lib/lsb/install_initd /etc/init.d/@install_name@ fi fi %if "%{name}" != "yule" cat << EOF Samhain is installed but is NOT running yet, and the database of file signatures is NOT initialized yet. Read the documentation, review configuration files, and then (i) initialize it (@sbindir@/samhain -t init) and (ii) start it manually (@sbindir@/samhain start). It is configured to start automatically on the next boot for runlevels [2-5]. EOF %endif %if "%{name}" == "yule" cat << EOF Yule is installed but is NOT running yet, read the documentation, review configuration files, and then start it (@sbindir@/yule) It is configured to start automatically on the next boot for runlevels [2-5]. EOF %endif %preun # stop running instance of samhain, if any if [ -f @mylockdir@/%{name}.pid ]; then @sbindir@/@install_name@ stop fi if [ "$1" = 0 ]; then # remove boot-time scripts and links cd @mydataroot@ if [ -f ./samhain-install.sh ]; then /bin/sh ./samhain-install.sh --verbose uninstall-boot else if test -f /usr/lib/lsb/remove_initd; then /usr/lib/lsb/remove_initd /etc/init.d/@install_name@ fi rm -f /etc/init.d/@install_name@ fi fi %postun if [ "$1" = 0 ]; then # remove any kernel modules that might have been installed RVER=`uname -r` MODFILES=`ls /lib/modules/$RVER/@install_name@* 2>/dev/null` if test "x$MODFILES" = x; then : else rm -f /lib/modules/$RVER/@install_name@* fi fi %files -f sh_file_list %defattr(-,root,root) %dir @mylockdir@ %dir @mylogdir@ %doc docs/BUGS COPYING docs/Changelog docs/TODO %doc LICENSE docs/FAQ.html docs/HOWTO* docs/MANUAL-2_3.* docs/README* @mydataroot@ %if "%{withstg_prg}" == "xsamhain_stealth" @sbindir@/@install_name@_stealth %endif %if "%{withpwd_prg}" == "xDSH_WITH_CLIENT" @sbindir@/@install_name@_setpwd %endif %if "%{withpwd_prg}" == "xDSH_WITH_SERVER" @sbindir@/@install_name@ctl %exclude @sbindir@/@install_name@_setpwd %endif %attr(644,root,root) @mandir@/man5/@install_name@* %attr(644,root,root) @mandir@/man8/@install_name@* %attr(644,root,root) /etc/logrotate.d/@install_name@ %config(noreplace) @myrpmconffile@ %changelog * Tue May 16 2006 Rainer Wichmann - fix manual version, noticed by Imre Gergely * Tue Apr 05 2005 Rainer Wichmann - disable automatic stripping, use sstrip * Thu Mar 17 2005 Rainer Wichmann - fixes for enable-khide * Wed Oct 20 2004 Rainer Wichmann - more fixes for client/server detection - fix for samhain_stealth * Sun Aug 15 2004 Rainer Wichmann - fix detection of client/server * Sat Jun 19 2004 Rainer Wichmann - replace ./test.sh $i with make test$i - add logic for rpm-light (remove some more files after install) - make postun posix compliant (avoid empty argument list for rm -f) * Wed Dec 31 2003 Stijn Jonker - Fixed correctly build of yule-*-rpm - Fixed excluding of yule_setpwd, and including of yulectl on yule build - Fixed including of samhain_setpwd in samhain client build - Above changes required for correct build in newer rpms, with defaults for abort on unpacked files due to %_unpackaged_files_terminate_build 1 setting - Fixed installation text for yule, not to display samhain text - Added /sbin/chkconfig install_name on to enable the rc scripts * Thu Dec 11 2003 Christian Vanguers - Fixed typo in samhain.spec - Compiled on RedHat Enterprise Linux ES 3 * Thu Mar 26 2003 Rainer Wichmann - strip REQ_FROM_SERVER in config file path (%config(noreplace) ...) * Sun Jan 12 2003 Rainer Wichmann - replace %configure with ./configure * Tue Dec 24 2002 Rainer Wichmann - backported applicable changes to samhain.spec.in - warn user that database must be initialized - fix version of MANUAL in '%files' - test for chkconfig, use only if found * Sun Dec 22 2002 Andre Oliveira da Costa 1.7.0 - fixed typo with _usr macro on ./configure - stops running samhain before uninstall - implemented conditionals to allow proper uninstalls/upgrades - 'BuildPreReq: gpg' is considered only if '--with gpg' is provided - run 'chkconfig' to activate samhain after installation - warn user that samhain must be manually started after install/upgrade * Fri Dec 20 2002 Rainer Wichmann - backported to samhain.spec.in (take over user's choices from configure) - also save samhain.startLSB and samhain.startSuSE for install-boot * Thu Dec 19 2002 Andre Oliveira da Costa 1.6.6 - optional parameters '--with gpg' and '--with tests' - use of pre-defined macros whenever possible * Wed Dec 18 2002 Andre Oliveira da Costa 1.6.6 - Fixed installation process, avoiding hardcoded paths on the binaries (thks to samhain's author Rainer Wichmann) * Mon Dec 16 2002 Andre Oliveira da Costa 1.6.6 - First attempt to build from sources