spec: Fix user/group creation, only call i2enfeature ido-mysql on fresh install.

refs #4772
refs #4811
This commit is contained in:
Michael Friedrich 2013-10-08 16:10:14 +02:00
parent bb0012e7b6
commit 61602240ab
1 changed files with 41 additions and 25 deletions

View File

@ -8,9 +8,13 @@
%endif %endif
%if "%{_vendor}" == "suse" %if "%{_vendor}" == "suse"
%define opensuse_boost_version 1_49_0 %define opensuse_boost_version 1_49_0
%define apacheuser www %define apacheuser wwwrun
%endif %endif
%define icinga_user icinga
%define icinga_group icinga
%define icingacmd_group icingacmd
%define logmsg logger -t %{name}/rpm %define logmsg logger -t %{name}/rpm
Summary: network monitoring application Summary: network monitoring application
@ -64,12 +68,15 @@ Requires: libboost_thread%{opensuse_boost_version}
%endif %endif
Requires: %{name}-common = %{version} Requires: %{name}-common = %{version}
Requires: user(icinga)
Requires(pre): user(icinga) %if "%{_vendor}" == "redhat"
Requires: group(icinga) Requires: user(%{icinga_user})
Requires(pre): group(icinga) Requires(pre): user(%{icinga_user})
Requires: group(icingacmd) Requires: group(%{icinga_group})
Requires(pre): group(icingacmd) Requires(pre): group(%{icinga_group})
Requires: group(%{icingacmd_group})
Requires(pre): group(%{icingacmd_group})
%endif
%description %description
Icinga is a general-purpose network monitoring application. Icinga is a general-purpose network monitoring application.
@ -77,11 +84,13 @@ Icinga is a general-purpose network monitoring application.
%package common %package common
Summary: Common Icinga 2 configuration Summary: Common Icinga 2 configuration
Group: Applications/System Group: Applications/System
%if "%{_vendor}" == "redhat"
Requires(pre): shadow-utils Requires(pre): shadow-utils
Requires(post): shadow-utils Requires(post): shadow-utils
Provides: user(icinga) Provides: user(%{icinga_user})
Provides: group(icinga) Provides: group(%{icinga_group})
Provides: group(icingacmd) Provides: group(%{icingacmd_group})
%endif
%description common %description common
Provides common directories, uid and gid among Icinga 2 related Provides common directories, uid and gid among Icinga 2 related
@ -142,36 +151,43 @@ make install \
[ "%{buildroot}" != "/" ] && [ -d "%{buildroot}" ] && rm -rf %{buildroot} [ "%{buildroot}" != "/" ] && [ -d "%{buildroot}" ] && rm -rf %{buildroot}
%pre common %pre common
getent group icinga >/dev/null || groupadd -r icinga getent group %{icinga_group} >/dev/null || %{_sbindir}/groupadd -r %{icinga_group}
getent group icingacmd >/dev/null || groupadd -r icingacmd getent group %{icingacmd_group} >/dev/null || %{_sbindir}/groupadd -r %{icingacmd_group}
getent passwd icinga >/dev/null || /useradd -c "icinga" -s /sbin/nologin -r -d %{_localstatedir}/spool/%{name} -G icingacmd -g icinga icinga 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 exit 0
%preun %preun
if [ $1 = 0 ]; then if [ "$1" = "0" ]; then
/sbin/service %{name} stop &>/dev/null || : /sbin/service %{name} stop &>/dev/null || :
/sbin/chkconfig --del %{name} || : /sbin/chkconfig --del %{name} || :
fi fi
%post %post
%{_sbindir}/usermod -a -G icingacmd %{apacheuser} || : %{_sbindir}/usermod -a -G %{icingacmd_group} %{apacheuser} || :
/sbin/chkconfig --add %{name} || : /sbin/chkconfig --add %{name} || :
/sbin/service %{name} start &>/dev/null || : /sbin/service %{name} start &>/dev/null || :
%post ido-mysql %post ido-mysql
ln -s %{_sysconfdir}/%{name}/features-available/ido-mysql.conf %{_sysconfdir}/%{name}/features-enabled/ido-mysql.conf if [ ${1:-0} -eq 1 ]
then
# initial installation, enable ido-mysql feature
%{_sbindir}/i2enfeature ido-mysql
fi
%postun ido-mysql %postun ido-mysql
[ -f "%{_sysconfdir}/%{name}/features-enabled/ido-mysql.conf" ] && rm -f %{_sysconfdir}/%{name}/features-enabled/ido-mysql.conf if [ "$1" = "0" ]; then
# deinstallation of the package - remove feature
test -x %{_sbindir}/i2disfeature && %{_sbindir}/i2disfeature ido-mysql
fi
%files %files
%defattr(-,root,root) %defattr(-,root,root)
%doc README AUTHORS ChangeLog COPYING COPYING.Exceptions %doc README AUTHORS ChangeLog COPYING COPYING.Exceptions
%attr(755,-,-) %{_sysconfdir}/init.d/%{name} %attr(755,-,-) %{_sysconfdir}/init.d/%{name}
%attr(0750,icinga,icinga) %dir %{_sysconfdir}/%{name}/conf.d %attr(0750,%{icinga_user},%{icinga_group}) %dir %{_sysconfdir}/%{name}/conf.d
%attr(0750,icinga,icinga) %dir %{_sysconfdir}/%{name}/features-available %attr(0750,%{icinga_user},%{icinga_group}) %dir %{_sysconfdir}/%{name}/features-available
%attr(0750,icinga,icinga) %dir %{_sysconfdir}/%{name}/features-enabled %attr(0750,%{icinga_user},%{icinga_group}) %dir %{_sysconfdir}/%{name}/features-enabled
%config(noreplace) %{_sysconfdir}/%{name}/%{name}.conf %config(noreplace) %{_sysconfdir}/%{name}/%{name}.conf
%config(noreplace) %{_sysconfdir}/%{name}/conf.d/*.conf %config(noreplace) %{_sysconfdir}/%{name}/conf.d/*.conf
%config(noreplace) %{_sysconfdir}/%{name}/features-available/*.conf %config(noreplace) %{_sysconfdir}/%{name}/features-available/*.conf
@ -186,16 +202,16 @@ ln -s %{_sysconfdir}/%{name}/features-available/ido-mysql.conf %{_sysconfdir}/%{
%{_mandir}/man8/%{name}.8.gz %{_mandir}/man8/%{name}.8.gz
%{_localstatedir}/cache/%{name} %{_localstatedir}/cache/%{name}
%attr(0750,icinga,icinga) %dir %{_localstatedir}/log/%{name} %attr(0750,%{icinga_user},%{icinga_group}) %dir %{_localstatedir}/log/%{name}
%attr(0750,icinga,icinga) %dir %{_localstatedir}/log/%{name}/compat %attr(0750,%{icinga_user},%{icinga_group}) %dir %{_localstatedir}/log/%{name}/compat
%attr(0750,icinga,icinga) %dir %{_localstatedir}/log/%{name}/compat/archives %attr(0750,%{icinga_user},%{icinga_group}) %dir %{_localstatedir}/log/%{name}/compat/archives
%{_localstatedir}/run/%{name} %{_localstatedir}/run/%{name}
%{_localstatedir}/lib/%{name} %{_localstatedir}/lib/%{name}
%attr(2755,icinga,icingacmd) %{_localstatedir}/run/icinga2/cmd %attr(2755,%{icinga_user},%{icingacmd_group}) %{_localstatedir}/run/icinga2/cmd
%files common %files common
%attr(0750,icinga,icinga) %dir %{_localstatedir}/spool/%{name} %attr(0750,%{icinga_user},%{icinga_group}) %dir %{_localstatedir}/spool/%{name}
%files doc %files doc
%doc README AUTHORS ChangeLog COPYING COPYING.Exceptions %doc README AUTHORS ChangeLog COPYING COPYING.Exceptions