aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichal Schmidt <mschmidt@redhat.com>2012-06-14 16:54:50 +0200
committerBill Nottingham <notting@redhat.com>2012-06-29 17:13:00 -0400
commit6342995a8951fba570ccc0689094a36513958bea (patch)
treece03f3d215fc6139aff3f55aada1ecf99bb11d82
parent7584a3f5351dc6292bd0a5b5548749268b30b75d (diff)
downloadinitscripts-6342995a8951fba570ccc0689094a36513958bea.tar
initscripts-6342995a8951fba570ccc0689094a36513958bea.tar.gz
initscripts-6342995a8951fba570ccc0689094a36513958bea.tar.bz2
initscripts-6342995a8951fba570ccc0689094a36513958bea.tar.xz
initscripts-6342995a8951fba570ccc0689094a36513958bea.zip
service: add support for legacy custom actions
This adds support for legacy initscript actions such as service iptables save Packages wishing to provide legacy actions should install programs (probably scripts, but could be binaries) named /usr/libexec/initscripts/legacy-actions/<service>/<action> It should be emphasized that this feature is meant to be used only in packages where compatibility of custom actions with previous releases is desired. Adding of entirely new actions is discouraged. Useful tools should be shipped by upstreams as programs in /usr/bin, not in distro-specific hacks. [ Modifications from original : change from /usr/lib to /usr/libexec - notting ] https://bugzilla.redhat.com/show_bug.cgi?id=796663
-rw-r--r--Makefile1
-rw-r--r--initscripts.spec1
-rwxr-xr-xservice14
3 files changed, 12 insertions, 4 deletions
diff --git a/Makefile b/Makefile
index 3d1ae951..9e454f26 100644
--- a/Makefile
+++ b/Makefile
@@ -143,6 +143,7 @@ install:
ln -s rc.d/$$i $(ROOT)/etc/$$i; \
done
+ mkdir -p -m 755 $(ROOT)/usr/libexec/initscripts/legacy-actions
syntax-check:
diff --git a/initscripts.spec b/initscripts.spec
index 974f9561..01c59324 100644
--- a/initscripts.spec
+++ b/initscripts.spec
@@ -301,6 +301,7 @@ rm -rf $RPM_BUILD_ROOT
%ghost %verify(not md5 size mtime) %config(noreplace,missingok) /etc/crypttab
%dir /etc/tmpfiles.d
/etc/tmpfiles.d/initscripts.conf
+%dir /usr/libexec/initscripts/legacy-actions
%files legacy
%defattr(-,root,root)
diff --git a/service b/service
index 6aabd6fc..86b6f29f 100755
--- a/service
+++ b/service
@@ -5,8 +5,10 @@
VERSION="$(basename $0) ver. 0.91"
USAGE="Usage: $(basename $0) < option > | --status-all | \
[ service_name [ command | --full-restart ] ]"
-SERVICE=
SERVICEDIR="/etc/init.d"
+ACTIONDIR="/usr/libexec/initscripts/legacy-actions"
+SERVICE=
+ACTION=
OPTIONS=
if [ $# -eq 0 ]; then
@@ -58,6 +60,8 @@ while [ $# -gt 0 ]; do
fi
elif [ -z "${SERVICE}" ]; then
SERVICE="${1}"
+ elif [ -z "${ACTION}" ]; then
+ ACTION="${1}"
else
OPTIONS="${OPTIONS} ${1}"
fi
@@ -67,8 +71,10 @@ while [ $# -gt 0 ]; do
done
if [ -f "${SERVICEDIR}/${SERVICE}" ]; then
- env -i PATH="$PATH" TERM="$TERM" SYSTEMCTL_IGNORE_DEPENDENCIES=${SYSTEMCTL_IGNORE_DEPENDENCIES} SYSTEMCTL_SKIP_REDIRECT=${SYSTEMCTL_SKIP_REDIRECT} "${SERVICEDIR}/${SERVICE}" ${OPTIONS}
+ env -i PATH="$PATH" TERM="$TERM" SYSTEMCTL_IGNORE_DEPENDENCIES=${SYSTEMCTL_IGNORE_DEPENDENCIES} SYSTEMCTL_SKIP_REDIRECT=${SYSTEMCTL_SKIP_REDIRECT} "${SERVICEDIR}/${SERVICE}" ${ACTION} ${OPTIONS}
+elif [ -x "${ACTIONDIR}/${SERVICE}/${ACTION}" ]; then
+ env -i PATH="$PATH" TERM="$TERM" SYSTEMCTL_IGNORE_DEPENDENCIES=${SYSTEMCTL_IGNORE_DEPENDENCIES} SYSTEMCTL_SKIP_REDIRECT=${SYSTEMCTL_SKIP_REDIRECT} "${ACTIONDIR}/${SERVICE}/${ACTION}" ${OPTIONS}
else
- echo $"Redirecting to /bin/systemctl ${OPTIONS} ${SERVICE}.service" >&2
- exec /bin/systemctl ${OPTIONS} ${SERVICE}.service
+ echo $"Redirecting to /bin/systemctl ${ACTION} ${OPTIONS} ${SERVICE}.service" >&2
+ exec /bin/systemctl ${ACTION} ${OPTIONS} ${SERVICE}.service
fi