]> granicus.if.org Git - icinga2/blobdiff - icinga2.spec
Update "swap" check command.
[icinga2] / icinga2.spec
index c311807c6f84e38e4b2e3e361cca81e2ae557a29..12437e44ac64e68825938f77219dcef7f86abeb5 100644 (file)
@@ -1,6 +1,6 @@
 #/******************************************************************************
 # * Icinga 2                                                                   *
-# * Copyright (C) 2012-2013 Icinga Development Team (http://www.icinga.org/)   *
+# * Copyright (C) 2012-2014 Icinga Development Team (http://www.icinga.org)    *
 # *                                                                            *
 # * This program is free software; you can redistribute it and/or              *
 # * modify it under the terms of the GNU General Public License                *
 %define apachegroup apache
 %endif
 %if "%{_vendor}" == "suse"
+# opensuse 13
+%if 0%{?suse_version} >= 1310
+%define opensuse_boost_version 1_53_0
+%else
 %define opensuse_boost_version 1_49_0
+%endif
 %define sles_boost_version 1_54_0
 %define apachename apache2
 %define apacheconfdir  %{_sysconfdir}/apache2/conf.d
 %define icinga_user icinga
 %define icinga_group icinga
 %define icingacmd_group icingacmd
+%define icingaweb2name icingaweb2
+%define icingaweb2version 2.0.0
 
 %define icingaclassicconfdir %{_sysconfdir}/icinga
 
 %define logmsg logger -t %{name}/rpm
 
-Summary: network monitoring application
+Summary: Network monitoring application
 Name: icinga2
-Version: 0.0.3
+Version: 0.0.9
 Release: %{revision}%{?dist}
 License: GPLv2+
 Group: Applications/System
@@ -55,15 +62,28 @@ Source: %{name}-%{version}.tar.gz
 URL: http://www.icinga.org/
 BuildRoot:      %{_tmppath}/%{name}-%{version}-build
 
+Requires: %{name}-bin = %{version}
+#Requires: %{name}-ido-mysql = %{version}
+#Requires: %{icingaweb2name} >= %{icingaweb2version}
+
+%description
+Meta package for Icinga 2 Core, DB IDO and Web.
+
+%package bin
+Summary:      Icinga 2 binaries and libraries
+Group:        Applications/System
+
 BuildRequires: doxygen
+BuildRequires: pandoc
+BuildRequires: python-sphinx
 BuildRequires: openssl-devel
 BuildRequires: gcc-c++
 BuildRequires: libstdc++-devel
 BuildRequires: cmake
-BuildRequires: flex
+BuildRequires: flex >= 2.5.35
 BuildRequires: bison
-BuildRequires: %{apachename}
 
+# redhat
 %if "%{_vendor}" == "redhat"
 %if 0%{?el5} || 0%{?rhel} == 5 || "%{?dist}" == ".el5"
 # el5 requires EPEL
@@ -83,10 +103,16 @@ Requires: boost-thread >= 1.41
 Requires: boost-regex >= 1.41
 %endif
 %endif
+#redhat
 
+# suse
 %if "%{_vendor}" == "suse"
-%if 0%{?sles_version} == 11
-BuildRequires: libgfortran46
+# sles
+# note: sles_version macro is not set in SLES11 anymore
+# note: sles service packs are not under version control
+%if 0%{?suse_version} == 1110
+BuildRequires: gcc-fortran
+BuildRequires: libgfortran43
 BuildRequires: boost-license%{sles_boost_version}
 BuildRequires: boost-devel >= 1.41
 Requires: boost-license%{sles_boost_version}
@@ -94,7 +120,10 @@ Requires: libboost_program_options%{sles_boost_version}
 Requires: libboost_system%{sles_boost_version}
 Requires: libboost_test%{sles_boost_version}
 Requires: libboost_thread%{sles_boost_version}
-%else
+Requires: libboost_regex%{sles_boost_version}
+%endif
+# opensuse
+%if 0%{?suse_version} >= 1210
 BuildRequires: boost-devel >= 1.41
 Requires: libboost_program_options%{opensuse_boost_version}
 Requires: libboost_system%{opensuse_boost_version}
@@ -103,11 +132,13 @@ Requires: libboost_thread%{opensuse_boost_version}
 Requires: libboost_regex%{opensuse_boost_version}
 %endif
 %endif
+# suse
 
 Requires: %{name}-common = %{version}
 
-%description
-Icinga is a general-purpose network monitoring application.
+%description bin
+Icinga 2 is a general-purpose network monitoring application.
+Provides binaries and libraries for Icinga 2 Core.
 
 %package common
 Summary:      Common Icinga 2 configuration
@@ -136,7 +167,11 @@ Summary:      IDO MySQL database backend for Icinga 2
 Group:        Applications/System
 %if "%{_vendor}" == "suse"
 BuildRequires: libmysqlclient-devel
+%if 0%{?suse_version} >= 1210
 Requires: libmysqlclient18
+%else
+Requires: libmysqlclient15
+%endif
 %endif
 %if "%{_vendor}" == "redhat"
 # el5 only provides mysql package
@@ -180,6 +215,7 @@ IDOUtils schema >= 1.10
 %package classicui-config
 Summary:      Icinga 2 Classic UI Standalone configuration
 Group:        Applications/System
+BuildRequires: %{apachename}
 Requires:     %{apachename}
 Requires:     %{name} = %{version}-%{release}
 Provides:     icinga-classicui-config
@@ -204,12 +240,18 @@ CMAKE_OPTS="-DCMAKE_INSTALL_PREFIX=/usr \
             -DICINGA2_COMMAND_GROUP=%{icingacmd_group}"
 %if "%{_vendor}" == "redhat"
 %if 0%{?el5} || 0%{?rhel} == 5 || "%{?dist}" == ".el5"
+# Boost_VERSION 1.41.0 vs 101400 - disable build tests
+# details in https://dev.icinga.org/issues/5033
 CMAKE_OPTS="$CMAKE_OPTS -DBOOST_LIBRARYDIR=/usr/lib/boost141 \
  -DBOOST_INCLUDEDIR=/usr/include/boost141 \
- -DBoost_ADDITIONAL_VERSIONS='1.41;1.41.0'"
+ -DBoost_ADDITIONAL_VERSIONS='1.41;1.41.0' \
+ -DBoost_NO_SYSTEM_PATHS=TRUE \
+ -DBUILD_TESTING=FALSE \
+ -DBoost_NO_BOOST_CMAKE=TRUE"
 %endif
 %endif
-cmake $CMAKE_OPTS . 
+
+cmake $CMAKE_OPTS .
 
 make %{?_smp_mflags}
 
@@ -224,7 +266,12 @@ install -D -m 0644 etc/icinga/cgi.cfg %{buildroot}%{icingaclassicconfdir}/cgi.cf
 install -D -m 0644 etc/icinga/icinga-classic-apache.conf %{buildroot}%{apacheconfdir}/icinga.conf
 
 # fix plugin path on x64
-sed -i 's@plugindir = .*@plugindir = "%{_libdir}/nagios/plugins"@' %{buildroot}/%{_sysconfdir}/%{name}/conf.d/macros.conf
+%if "%{_vendor}" != "suse"
+sed -i 's@PluginDir = .*@PluginDir = "%{_libdir}/nagios/plugins"@' %{buildroot}/%{_sysconfdir}/%{name}/constants.conf
+%endif
+
+# remove features-enabled symlinks
+rm -f %{buildroot}/%{_sysconfdir}/%{name}/features-enabled/*.conf
 
 %clean
 [ "%{buildroot}" != "/" ] && [ -d "%{buildroot}" ] && rm -rf %{buildroot}
@@ -235,6 +282,70 @@ getent group %{icingacmd_group} >/dev/null || %{_sbindir}/groupadd -r %{icingacm
 getent passwd %{icinga_user} >/dev/null || %{_sbindir}/useradd -c "icinga" -s /sbin/nologin -r -d %{_localstatedir}/spool/%{name} -G %{icingacmd_group} -g %{icinga_group} %{icinga_user}
 exit 0
 
+# suse
+%if 0%{?suse_version}
+%post
+%{fillup_and_insserv icinga2}
+
+if [ ${1:-0} -eq 1 ]
+then
+       # initial installation, enable default features
+       %{_sbindir}/icinga2-enable-feature checker
+       %{_sbindir}/icinga2-enable-feature notification
+       %{_sbindir}/icinga2-enable-feature mainlog
+fi
+
+exit 0
+%postun
+%restart_on_update icinga2
+%insserv_cleanup
+
+if [ "$1" = "0" ]; then
+       # deinstallation of the package - remove enabled features
+       rm -rf %{_sysconfdir}/%{name}/features-enabled
+fi
+
+exit 0
+
+%preun
+%stop_on_removal icinga2
+
+# rhel
+%else
+
+%post
+/sbin/chkconfig --add icinga2
+
+if [ ${1:-0} -eq 1 ]
+then
+       # initial installation, enable default features
+       %{_sbindir}/icinga2-enable-feature checker
+       %{_sbindir}/icinga2-enable-feature notification
+       %{_sbindir}/icinga2-enable-feature mainlog
+fi
+
+exit 0
+
+%postun
+if [ "$1" -ge  "1" ]; then
+       /sbin/service icinga2 condrestart >/dev/null 2>&1 || :
+fi
+
+if [ "$1" = "0" ]; then
+       # deinstallation of the package - remove enabled features
+       rm -rf %{_sysconfdir}/%{name}/features-enabled
+fi
+
+exit 0
+%preun
+if [ "$1" = "0" ]; then
+       /sbin/service icinga2 stop > /dev/null 2>&1
+       /sbin/chkconfig --del icinga2
+fi
+
+%endif
+# suse/rhel
+
 %post ido-mysql
 if [ ${1:-0} -eq 1 ]
 then
@@ -242,12 +353,16 @@ then
        %{_sbindir}/icinga2-enable-feature ido-mysql
 fi
 
+exit 0
+
 %postun ido-mysql
 if [ "$1" = "0" ]; then
        # deinstallation of the package - remove feature
        test -x %{_sbindir}/icinga2-disable-feature && %{_sbindir}/icinga2-disable-feature ido-mysql
 fi
 
+exit 0
+
 %post ido-pgsql
 if [ ${1:-0} -eq 1 ]
 then
@@ -255,12 +370,16 @@ then
        %{_sbindir}/icinga2-enable-feature ido-pgsql
 fi
 
+exit 0
+
 %postun ido-pgsql
 if [ "$1" = "0" ]; then
        # deinstallation of the package - remove feature
        test -x %{_sbindir}/icinga2-disable-feature && %{_sbindir}/icinga2-disable-feature ido-pgsql
 fi
 
+exit 0
+
 %post classicui-config
 if [ ${1:-0} -eq 1 ]
 then
@@ -270,6 +389,8 @@ then
         %{_sbindir}/icinga2-enable-feature command
 fi
 
+exit 0
+
 %postun classicui-config
 if [ "$1" = "0" ]; then
         # deinstallation of the package - remove feature
@@ -278,17 +399,24 @@ if [ "$1" = "0" ]; then
         test -x %{_sbindir}/icinga2-disable-feature && %{_sbindir}/icinga2-disable-feature command
 fi
 
+exit 0
+
 %files
+
+%files bin
 %defattr(-,root,root,-)
 %doc COPYING COPYING.Exceptions README NEWS AUTHORS ChangeLog
 %attr(755,-,-) %{_sysconfdir}/init.d/%{name}
+%attr(0750,%{icinga_user},%{icinga_group}) %dir %{_sysconfdir}/%{name}
 %attr(0750,%{icinga_user},%{icinga_group}) %dir %{_sysconfdir}/%{name}/conf.d
 %attr(0750,%{icinga_user},%{icinga_group}) %dir %{_sysconfdir}/%{name}/features-available
 %attr(0750,%{icinga_user},%{icinga_group}) %dir %{_sysconfdir}/%{name}/features-enabled
+%attr(0750,%{icinga_user},%{icinga_group}) %dir %{_sysconfdir}/%{name}/scripts
 %config(noreplace) %attr(0640,%{icinga_user},%{icinga_group}) %{_sysconfdir}/%{name}/%{name}.conf
+%config(noreplace) %attr(0640,%{icinga_user},%{icinga_group}) %{_sysconfdir}/%{name}/constants.conf
 %config(noreplace) %attr(0640,%{icinga_user},%{icinga_group}) %{_sysconfdir}/%{name}/conf.d/*.conf
 %config(noreplace) %attr(0640,%{icinga_user},%{icinga_group}) %{_sysconfdir}/%{name}/features-available/*.conf
-%config(noreplace) %attr(0640,%{icinga_user},%{icinga_group}) %{_sysconfdir}/%{name}/features-enabled/*.conf
+%config(noreplace) %{_sysconfdir}/%{name}/scripts/*
 %{_sbindir}/%{name}
 %{_bindir}/%{name}-migrate-config
 %{_bindir}/%{name}-build-ca
@@ -296,6 +424,7 @@ fi
 %{_sbindir}/%{name}-enable-feature
 %{_sbindir}/%{name}-disable-feature
 %exclude %{_libdir}/%{name}/libdb_ido_mysql*
+%exclude %{_libdir}/%{name}/libdb_ido_pgsql*
 %{_libdir}/%{name}
 %{_datadir}/%{name}
 %exclude %{_datadir}/%{name}/itl
@@ -305,15 +434,18 @@ fi
 %attr(0755,%{icinga_user},%{icinga_group}) %dir %{_localstatedir}/log/%{name}
 %attr(0755,%{icinga_user},%{icinga_group}) %dir %{_localstatedir}/log/%{name}/compat
 %attr(0755,%{icinga_user},%{icinga_group}) %dir %{_localstatedir}/log/%{name}/compat/archives
-%attr(0755,%{icinga_user},%{icinga_group}) %{_localstatedir}/run/%{name}
+%attr(0755,%{icinga_user},%{icinga_group}) %ghost %{_localstatedir}/run/%{name}
 %attr(0750,%{icinga_user},%{icinga_group}) %{_localstatedir}/lib/%{name}
 
-%attr(2755,%{icinga_user},%{icingacmd_group}) %{_localstatedir}/run/icinga2/cmd
+%attr(2755,%{icinga_user},%{icingacmd_group}) %ghost %{_localstatedir}/run/icinga2/cmd
 
 %files common
 %defattr(-,root,root,-)
 %doc COPYING COPYING.Exceptions README NEWS AUTHORS ChangeLog
+%attr(755,-,-) %{_sysconfdir}/logrotate.d/%{name}
 %attr(0750,%{icinga_user},%{icinga_group}) %dir %{_localstatedir}/spool/%{name}
+%attr(0750,%{icinga_user},%{icinga_group}) %dir %{_localstatedir}/spool/%{name}/perfdata
+%attr(0750,%{icinga_user},%{icinga_group}) %dir %{_localstatedir}/spool/%{name}/tmp
 %attr(0750,%{icinga_user},%{icinga_group}) %dir %{_datadir}/%{name}/itl
 %{_datadir}/%{name}/itl
 
@@ -335,20 +467,10 @@ fi
 
 %files classicui-config
 %defattr(-,root,root,-)
+%attr(0751,%{icinga_user},%{icinga_group}) %dir %{icingaclassicconfdir}
 %config(noreplace) %{icingaclassicconfdir}/cgi.cfg
 %config(noreplace) %{apacheconfdir}/icinga.conf
 %config(noreplace) %attr(0640,root,%{apachegroup}) %{icingaclassicconfdir}/passwd
 
 
 %changelog
-* Tue Oct 01 2013 Michael Friedrich <michael.friedrich@netways.de> - 0.0.3-1
-- revamp package
-
-* Sat May 04 2013 Michael Friedrich <michael.friedrich@netways.de> - 0.0.2-1
-- new initscript in initdir
-- itl is installed into datadir
-- man pages in mandir
-- use name macro to avoid typos
-
-* Fri Nov 19 2012 Gunnar Beutner <gunnar.beutner@netways.de> - 0.0.1-1
-- initial version