]> granicus.if.org Git - icinga2/blobdiff - icinga2.spec
Update "swap" check command.
[icinga2] / icinga2.spec
index 600722dce0c01a79a6b6bc15aa90b523f37c6f01..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
@@ -40,6 +45,8 @@
 %define icinga_user icinga
 %define icinga_group icinga
 %define icingacmd_group icingacmd
+%define icingaweb2name icingaweb2
+%define icingaweb2version 2.0.0
 
 %define icingaclassicconfdir %{_sysconfdir}/icinga
 
@@ -47,7 +54,7 @@
 
 Summary: Network monitoring application
 Name: icinga2
-Version: 0.0.4
+Version: 0.0.9
 Release: %{revision}%{?dist}
 License: GPLv2+
 Group: Applications/System
@@ -55,14 +62,26 @@ 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"
@@ -117,8 +136,9 @@ Requires: libboost_regex%{opensuse_boost_version}
 
 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
@@ -195,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
@@ -219,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}
 
@@ -240,9 +267,12 @@ install -D -m 0644 etc/icinga/icinga-classic-apache.conf %{buildroot}%{apachecon
 
 # fix plugin path on x64
 %if "%{_vendor}" != "suse"
-sed -i 's@plugindir = .*@plugindir = "%{_libdir}/nagios/plugins"@' %{buildroot}/%{_sysconfdir}/%{name}/conf.d/macros.conf
+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}
 
@@ -252,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
@@ -308,6 +402,8 @@ fi
 exit 0
 
 %files
+
+%files bin
 %defattr(-,root,root,-)
 %doc COPYING COPYING.Exceptions README NEWS AUTHORS ChangeLog
 %attr(755,-,-) %{_sysconfdir}/init.d/%{name}
@@ -317,9 +413,9 @@ exit 0
 %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) %{_sysconfdir}/%{name}/features-enabled/*.conf
 %config(noreplace) %{_sysconfdir}/%{name}/scripts/*
 %{_sbindir}/%{name}
 %{_bindir}/%{name}-migrate-config
@@ -346,6 +442,7 @@ exit 0
 %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