[packages/ejabberd] systemd service and stuff

jajcus jajcus at pld-linux.org
Fri Nov 15 20:55:04 CET 2013


commit 672716271ca346d2e5655b5df7c9066fc0edb8d0
Author: Jacek Konieczny <jajcus at jajcus.net>
Date:   Fri Nov 15 20:08:50 2013 +0100

    systemd service and stuff
    
    – systemd service added
    – %%triggerprein added to work-around bug in old init script
      and make sure the service is properly restarted

 ejabberd.service | 16 ++++++++++++++++
 ejabberd.spec    | 38 ++++++++++++++++++++++++++++++++------
 2 files changed, 48 insertions(+), 6 deletions(-)
---
diff --git a/ejabberd.spec b/ejabberd.spec
index f3087de..44194bc 100644
--- a/ejabberd.spec
+++ b/ejabberd.spec
@@ -1,6 +1,3 @@
-#
-# TODO:
-#	- add systemd unit
 
 # Conditional build:
 %bcond_with	pam		# PAM authentication support
@@ -20,6 +17,7 @@ Source0:	http://www.process-one.net/downloads/ejabberd/%{version}/%{realname}-%{
 # Source0-md5:	94ce4fe244ee72771eeafe27209d6d3c
 Source1:	%{realname}.init
 Source2:	%{realname}.sysconfig
+Source3:	%{realname}.service
 #
 # Archives created with the ejabberd-pack_deps.sh script (in this repo)
 Source10:	ejabberd-goldrush-20131108.tar.gz
@@ -68,7 +66,7 @@ BuildRequires:	openssl-devel
 %if %{with pam}
 BuildRequires:	pam-devel
 %endif
-BuildRequires:	rpmbuild(macros) >= 1.268
+BuildRequires:	rpmbuild(macros) >= 1.671
 BuildRequires:	yaml-devel
 BuildRequires:	zlib-devel
 BuildRequires:	git-core
@@ -77,9 +75,11 @@ Requires(post):	jabber-common
 Requires(post):	sed >= 4.0
 Requires(post):	textutils
 Requires(post,preun):	/sbin/chkconfig
+Requires(post,preun,postun):	systemd-units >= 38
 Requires:	erlang
 Requires:	expat >= 1.95
 Requires:	rc-scripts
+Requires:	systemd-units >= 38
 BuildRoot:	%{tmpdir}/%{name}-%{version}-root-%(id -u -n)
 
 %define		_noautoprovfiles	%{_libdir}/%{name}/priv/lib/
@@ -168,7 +168,8 @@ cd ../..
 
 %install
 rm -rf $RPM_BUILD_ROOT
-install -d $RPM_BUILD_ROOT{/var/lib/%{realname},/etc/{sysconfig,rc.d/init.d},%{_sbindir}}
+install -d $RPM_BUILD_ROOT{/var/lib/%{realname},/etc/{sysconfig,rc.d/init.d}} \
+		$RPM_BUILD_ROOT{%{systemdunitdir},%{_sbindir}}
 
 unset GIT_DIR GIT_WORK_TREE
 
@@ -180,6 +181,7 @@ unset GIT_DIR GIT_WORK_TREE
 
 sed -e's, at libdir@,%{_libdir},g' -e 's, at EJABBERD_DOC_PATH@,%{_docdir}/%{name}-%{version}/doc,g' %{SOURCE1} > $RPM_BUILD_ROOT/etc/rc.d/init.d/%{realname}
 install %{SOURCE2} $RPM_BUILD_ROOT/etc/sysconfig/%{realname}
+install %{SOURCE3} $RPM_BUILD_ROOT%{systemdunitdir}/%{name}.service
 
 chmod u+rw $RPM_BUILD_ROOT%{_sbindir}/%{realname}*
 
@@ -196,7 +198,7 @@ rm -rf $RPM_BUILD_ROOT
 
 %pre
 if [ -e /etc/jabber/ejabberd.cfg ] ; then
-	if grep -Eq '^[^#]*access_get' ; then
+	if grep -Eq '^[^#]*access_get' /etc/jabber/ejabberd.cfg ; then
 		echo "Your 'ejabberd.cfg' config file seems to use 'access_get' option of mod_vcard" >&2
 		echo "this is not supported by this ejabberd version in PLD" >&2
 		exit 1
@@ -221,11 +223,33 @@ fi
 /sbin/chkconfig --add ejabberd
 %service ejabberd restart "ejabberd server"
 
+%systemd_post %{name}.service
+
 %preun
 if [ "$1" = "0" ]; then
 	%service ejabberd stop
 	/sbin/chkconfig --del ejabberd
 fi
+%systemd_preun %{name}.service
+
+%postun
+%systemd_reload
+
+%triggerprein -- %{name} < 13.10
+# only if started and we know upgrade won't be aborted in %%pre
+if [ -e /var/lock/subsys/ejabberd ] && ! grep -Eq '^[^#]*access_get' /etc/jabber/ejabberd.cfg 2>/dev/null ; then
+	# old init script won't stop ejabberd correctly
+	# stop it's all processes here
+	# we assume any 'epmd', 'beam', 'beam.smp' or 'heart' process
+	# running with uid of jabber is ejabberd process
+	pids="$(ps -C "epmd beam beam.smp heart" -o pid=,user= | awk '/jabber/ { print $1 }')" || :
+	if [ -n "$pids" ] ; then
+		%banner -e %{name} <<'EOF'
+Killing all 'epmd, beam, beam.smp, heart' processed owned by the 'jabber' user to make sure old ejabberd is down.
+EOF
+		kill $pids || :
+	fi
+fi
 
 %triggerpostun -- %{name} < 13.10
 # convert old 'NODENAME' in /etc/sysconfig/ejabberd
@@ -248,6 +272,7 @@ if [ -e /etc/sysconfig/ejabberd ] ; then
 		/etc/sysconfig/ejabberd || :
 fi
 cp %{_sysconfdir}/jabber/cookie /var/lib/ejabberd/.erlang.cookie || :
+%systemd_trigger %{name}.service
 
 %files
 %defattr(644,root,root,755)
@@ -267,6 +292,7 @@ cp %{_sysconfdir}/jabber/cookie /var/lib/ejabberd/.erlang.cookie || :
 %ghost %attr(400,jabber,jabber) %ghost %config(noreplace) %verify(not md5 mtime size) /var/lib/ejabberd/.erlang.cookie
 %attr(754,root,root) /etc/rc.d/init.d/%{realname}
 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/%{realname}
+%{systemdunitdir}/%{name}.service
 
 %if %{with logdb}
 %files logdb
diff --git a/ejabberd.service b/ejabberd.service
new file mode 100644
index 0000000..bddf659
--- /dev/null
+++ b/ejabberd.service
@@ -0,0 +1,16 @@
+[Unit]
+Description=Fault-tolerant distributed Jabber/XMPP server
+After=network.target
+
+[Service]
+Type=forking
+Environment=EJABBERD_PID_PATH=/var/run/jabber/ejabberd.pid
+ExecStart=/usr/sbin/ejabberdctl start
+ExecStartPost=/usr/sbin/ejabberdctl started
+ExecStop=/usr/sbin/ejabberdctl stop
+ExecStopPost=/usr/sbin/ejabberdctl stopped
+PIDFile=/var/run/jabber/ejabberd.pid
+User=jabber
+
+[Install]
+WantedBy=multi-user.target
================================================================

---- gitweb:

http://git.pld-linux.org/gitweb.cgi/packages/ejabberd.git/commitdiff/9a105ba4017a8b53a31f1402aa2f14ffe466f915



More information about the pld-cvs-commit mailing list