Ship systemd service unit instead of SysV initscript (bug #690766).

Note: no socket activation yet.
This commit is contained in:
Tim Waugh 2011-06-29 13:07:24 +01:00
parent a4221da3e9
commit b7d9a11244
3 changed files with 53 additions and 161 deletions

146
cups.init
View File

@ -1,146 +0,0 @@
#!/bin/sh
#
# "$Id: cups.sh,v 1.10 2000/03/30 05:19:16 mike Exp $"
#
# Startup/shutdown script for the Common UNIX Printing System (CUPS).
#
# Linux chkconfig stuff:
#
# chkconfig: 2345 25 10
# description: Startup/shutdown script for the Common UNIX \
# Printing System (CUPS).
#
# Copyright 1997-2000 by Easy Software Products, all rights reserved.
#
# These coded instructions, statements, and computer programs are the
# property of Easy Software Products and are protected by Federal
# copyright law. Distribution and use rights are outlined in the file
# "LICENSE.txt" which should have been included with this file. If this
# file is missing or damaged please contact Easy Software Products
# at:
#
# Attn: CUPS Licensing Information
# Easy Software Products
# 44141 Airport View Drive, Suite 204
# Hollywood, Maryland 20636-3111 USA
#
# Voice: (301) 373-9603
# EMail: cups-info@cups.org
# WWW: http://www.cups.org
#
# heavily edited so that it's more like other scripts in init.d on Red Hat
# Linux
#
### BEGIN INIT INFO
# Provides: cups
# Required-Start: $syslog $local_fs
# Required-Stop: $syslog $local_fs
# Should-Start: portreserve
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: The CUPS scheduler
# Description: The CUPS scheduler
### END INIT INFO
# Source function library.
. /etc/rc.d/init.d/functions
DAEMON=cupsd
exec=/usr/sbin/cupsd
prog=cups
config=/etc/cups/cupsd.conf
lockfile=/var/lock/subsys/cups
check() {
# Check that we're a privileged user
[ `id -u` = 0 ] || exit 4
# Check if cupsd is executable
[ -x $exec ] || exit 5
}
start () {
check
[ -f $config ] || exit 6
echo -n $"Starting $prog: "
# tell portreserve to release the port
[ -x /sbin/portrelease ] && /sbin/portrelease cups &>/dev/null || :
# start daemon
daemon $DAEMON
RETVAL=$?
echo
[ $RETVAL = 0 ] && touch $lockfile
udevadm trigger --subsystem-match=usb \
--attr-match=bInterfaceClass=07 \
--attr-match=bInterfaceSubClass=01 \
--action=add &>/dev/null || :
udevadm trigger --subsystem-match=usb \
--property-match=DEVNAME="/dev/usb/lp*" \
--action=add &>/dev/null || :
return 0
}
stop () {
check
# stop daemon
echo -n $"Stopping $prog: "
killproc $DAEMON
RETVAL=$?
echo
[ $RETVAL = 0 ] && rm -f $lockfile
return 0
}
restart() {
stop
start
}
case $1 in
start)
start
;;
stop)
stop
;;
restart)
restart
;;
condrestart|try-restart)
[ -f $lockfile ] && restart || :
;;
reload)
echo -n $"Reloading $prog: "
killproc $DAEMON -HUP
RETVAL=$?
echo
;;
force-reload)
echo -n $"Reloading $prog: "
if ! killproc $DAEMON -HUP; then
restart
fi
echo
;;
status)
status -l $(basename $lockfile) $DAEMON
RETVAL=$?
;;
restartlog)
stop
cat /dev/null >/var/log/cups/error_log
start
;;
*)
echo $"Usage: $prog {start|stop|restart|restartlog|condrestart|try-restart|reload|force-reload|status}"
exit 2
esac
exit $RETVAL

15
cups.service Normal file
View File

@ -0,0 +1,15 @@
[Unit]
Description=CUPS scheduler
Requires=printer.target
After=syslog.target
[Service]
Type=forking
PIDFile=/var/run/cupsd.pid
ExecStartPre=/usr/sbin/cupsd -t
ExecStart=/usr/sbin/cupsd
ExecStartPost=/sbin/udevadm trigger --subsystem-match=usb --attr-match=bInterfaceClass=07 --attr-match=bInterfaceSubClass=01 --action=add
ExecStartPost=/sbin/udevadm trigger --subsystem-match=usb --property-match=DEVNAME="/dev/usb/lp*" --action=add
[Install]
WantedBy=multi-user.target

View File

@ -15,12 +15,12 @@
Summary: Common Unix Printing System Summary: Common Unix Printing System
Name: cups Name: cups
Version: 1.5 Version: 1.5
Release: 0.8.%{alphatag}%{?dist} Release: 0.9.%{alphatag}%{?dist}
License: GPLv2 License: GPLv2
Group: System Environment/Daemons Group: System Environment/Daemons
Source: http://ftp.easysw.com/pub/cups/%{version}%{alphatag}/cups-%{version}%{alphatag}-source.tar.bz2 Source: http://ftp.easysw.com/pub/cups/%{version}%{alphatag}/cups-%{version}%{alphatag}-source.tar.bz2
# Our initscript # Our systemd service unit
Source1: cups.init Source1: cups.service
# Pixmap for desktop file # Pixmap for desktop file
Source2: cupsprinter.png Source2: cupsprinter.png
# udev rules for libusb devices # udev rules for libusb devices
@ -106,6 +106,7 @@ BuildRequires: libtiff-devel
BuildRequires: krb5-devel BuildRequires: krb5-devel
BuildRequires: avahi-devel BuildRequires: avahi-devel
BuildRequires: poppler-utils BuildRequires: poppler-utils
BuildRequires: systemd-units
# Make sure we get postscriptdriver tags. # Make sure we get postscriptdriver tags.
BuildRequires: python-cups BuildRequires: python-cups
@ -128,6 +129,10 @@ Requires: tmpwatch
# Requires /etc/tmpfiles.d (bug #656566) # Requires /etc/tmpfiles.d (bug #656566)
Requires: systemd-units >= 13 Requires: systemd-units >= 13
Requires(post): systemd-units
Requires(preun): systemd-units
Requires(postun): systemd-units
Requires(post): systemd-sysv
# We use portreserve to prevent our TCP port being stolen. # We use portreserve to prevent our TCP port being stolen.
# Require the package here so that we know /etc/portreserve/ exists. # Require the package here so that we know /etc/portreserve/ exists.
@ -330,8 +335,8 @@ chmod 700 $RPM_BUILD_ROOT%{cups_serverbin}/backend/serial
rm -rf $RPM_BUILD_ROOT%{_initddir} \ rm -rf $RPM_BUILD_ROOT%{_initddir} \
$RPM_BUILD_ROOT%{_sysconfdir}/init.d \ $RPM_BUILD_ROOT%{_sysconfdir}/init.d \
$RPM_BUILD_ROOT%{_sysconfdir}/rc?.d $RPM_BUILD_ROOT%{_sysconfdir}/rc?.d
mkdir -p $RPM_BUILD_ROOT%{_initddir} mkdir -p $RPM_BUILD_ROOT%{_unitdir}
install -m 755 %{SOURCE1} $RPM_BUILD_ROOT%{_initddir}/cups install -m 755 %{SOURCE1} $RPM_BUILD_ROOT%{_unitdir}/%{name}.service
find $RPM_BUILD_ROOT%{_datadir}/cups/model -name "*.ppd" |xargs gzip -n9f find $RPM_BUILD_ROOT%{_datadir}/cups/model -name "*.ppd" |xargs gzip -n9f
@ -414,8 +419,11 @@ s:.*\('%{_datadir}'/\)\([^/_]\+\)\(.*\.po$\):%lang(\2) \1\2\3:
' > %{name}.lang ' > %{name}.lang
%post %post
/sbin/chkconfig --del cupsd 2>/dev/null || true # Make sure old versions aren't there anymore if [ $1 -eq 1 ] ; then
/sbin/chkconfig --add cups || true # Initial installation
/bin/systemctl daemon-reload >/dev/null 2>&1 || :
fi
# Remove old-style certs directory; new-style is /var/run # Remove old-style certs directory; new-style is /var/run
# (see bug #194581 for why this is necessary). # (see bug #194581 for why this is necessary).
/bin/rm -rf %{_sysconfdir}/cups/certs /bin/rm -rf %{_sysconfdir}/cups/certs
@ -433,8 +441,7 @@ s:.*\('%{_datadir}'/\)\([^/_]\+\)\(.*\.po$\):%lang(\2) \1\2\3:
--slave %{_mandir}/man1/lpq.1.gz print-lpqman %{_mandir}/man1/lpq-cups.1.gz \ --slave %{_mandir}/man1/lpq.1.gz print-lpqman %{_mandir}/man1/lpq-cups.1.gz \
--slave %{_mandir}/man1/lpr.1.gz print-lprman %{_mandir}/man1/lpr-cups.1.gz \ --slave %{_mandir}/man1/lpr.1.gz print-lprman %{_mandir}/man1/lpr-cups.1.gz \
--slave %{_mandir}/man1/lprm.1.gz print-lprmman %{_mandir}/man1/lprm-cups.1.gz \ --slave %{_mandir}/man1/lprm.1.gz print-lprmman %{_mandir}/man1/lprm-cups.1.gz \
--slave %{_mandir}/man1/lpstat.1.gz print-lpstatman %{_mandir}/man1/lpstat-cups.1.gz \ --slave %{_mandir}/man1/lpstat.1.gz print-lpstatman %{_mandir}/man1/lpstat-cups.1.gz
--initscript cups
%endif %endif
rm -f %{_localstatedir}/cache/cups/*.ipp %{_localstatedir}/cache/cups/*.cache rm -f %{_localstatedir}/cache/cups/*.ipp %{_localstatedir}/cache/cups/*.cache
exit 0 exit 0
@ -444,9 +451,10 @@ exit 0
%postun libs -p /sbin/ldconfig %postun libs -p /sbin/ldconfig
%preun %preun
if [ "$1" = "0" ]; then if [ $1 -eq 0 ] ; then
/sbin/service cups stop > /dev/null 2>&1 # Package removal, not upgrade
/sbin/chkconfig --del cups /bin/systemctl --no-reload disable %{name}.service >/dev/null 2>&1 || :
/bin/systemctl stop %{name}.service >/dev/null 2>&1 || :
%if %use_alternatives %if %use_alternatives
/usr/sbin/alternatives --remove print %{_bindir}/lpr.cups /usr/sbin/alternatives --remove print %{_bindir}/lpr.cups
%endif %endif
@ -454,11 +462,23 @@ fi
exit 0 exit 0
%postun %postun
if [ "$1" -ge "1" ]; then /bin/systemctl daemon-reload >/dev/null 2>&1 || :
/sbin/service cups condrestart > /dev/null 2>&1 if [ $1 -ge 1 ]; then
# Package upgrade, not uninstall
/bin/systemctl try-restart %{name}.service >/dev/null 2>&1 || :
fi fi
exit 0 exit 0
%triggerun -- %{name} < 1.5-0.9
# Save the current service runlevel info
# User must manually run systemd-sysv-convert --apply cups
# to migrate them to systemd targets
%{_bindir}/systemd-sysv-convert --save %{name} >/dev/null 2>&1 || :
# Run these because the SysV package being removed won't do them
/sbin/chkconfig --del cups >/dev/null 2>&1 || :
/bin/systemctl try-restart %{name}.service >/dev/null 2>&1 || :
%triggerin -- samba-client %triggerin -- samba-client
ln -sf ../../../bin/smbspool %{cups_serverbin}/backend/smb || : ln -sf ../../../bin/smbspool %{cups_serverbin}/backend/smb || :
exit 0 exit 0
@ -515,7 +535,7 @@ rm -rf $RPM_BUILD_ROOT
%doc %{_datadir}/%{name}/www/ja/index.html %doc %{_datadir}/%{name}/www/ja/index.html
%doc %{_datadir}/%{name}/www/pl/index.html %doc %{_datadir}/%{name}/www/pl/index.html
%doc %{_datadir}/%{name}/www/ru/index.html %doc %{_datadir}/%{name}/www/ru/index.html
%{_initddir}/cups %{_unitdir}/%{name}.service
%{_bindir}/cupstestppd %{_bindir}/cupstestppd
%{_bindir}/cupstestdsc %{_bindir}/cupstestdsc
%{_bindir}/cancel* %{_bindir}/cancel*
@ -614,6 +634,9 @@ rm -rf $RPM_BUILD_ROOT
%{_mandir}/man1/ipptool.1.gz %{_mandir}/man1/ipptool.1.gz
%changelog %changelog
* Wed Jun 29 2011 Tim Waugh <twaugh@redhat.com> 1:1.5-0.9.rc1
- Ship systemd service unit instead of SysV initscript (bug #690766).
* Wed Jun 29 2011 Tim Waugh <twaugh@redhat.com> 1:1.5-0.8.rc1 * Wed Jun 29 2011 Tim Waugh <twaugh@redhat.com> 1:1.5-0.8.rc1
- Tag localization files correctly (bug #716421). - Tag localization files correctly (bug #716421).