1#!/bin/sh
2#
3# restorecond:		Daemon used to maintain path file context
4#
5# chkconfig:	- 12 87
6# description:	restorecond uses inotify to look for creation of new files \
7# listed in the /etc/selinux/restorecond.conf file, and restores the \
8# correct security context.
9#
10# processname: /usr/sbin/restorecond
11# config: /etc/selinux/restorecond.conf
12# pidfile: /run/restorecond.pid
13#
14# Return values according to LSB for all commands but status:
15# 0 - success
16# 1 - generic or unspecified error
17# 2 - invalid or excess argument(s)
18# 3 - unimplemented feature (e.g. "reload")
19# 4 - insufficient privilege
20# 5 - program is not installed
21# 6 - program is not configured
22# 7 - program is not running
23
24PATH=/sbin:/bin:/usr/bin:/usr/sbin
25
26# Source function library.
27. /etc/rc.d/init.d/functions
28
29[ -x /usr/sbin/selinuxenabled ] && /usr/sbin/selinuxenabled || exit 7
30
31# Check that we are root ... so non-root users stop here
32test $EUID = 0  || exit 4
33
34test -x /usr/sbin/restorecond  || exit 5
35test -f /etc/selinux/restorecond.conf  || exit 6
36
37RETVAL=0
38
39start()
40{
41        echo -n $"Starting restorecond: "
42	unset HOME MAIL USER USERNAME
43        daemon /usr/sbin/restorecond
44	RETVAL=$?
45	touch /var/lock/subsys/restorecond
46        echo
47	return $RETVAL
48}
49
50stop()
51{
52        echo -n $"Shutting down restorecond: "
53	killproc restorecond
54	RETVAL=$?
55	rm -f  /var/lock/subsys/restorecond
56        echo
57	return $RETVAL
58}
59
60restart()
61{
62    stop
63    start
64}
65
66# See how we were called.
67case "$1" in
68  start)
69	start
70        ;;
71  stop)
72	stop
73        ;;
74  status)
75	status restorecond
76	RETVAL=$?
77	;;
78  force-reload|restart|reload)
79	restart
80	;;
81  condrestart)
82	[ -e /var/lock/subsys/restorecond ] && restart || :
83	;;
84  *)
85        echo $"Usage: $0 {start|stop|restart|force-reload|status|condrestart}"
86        RETVAL=3
87esac
88
89exit $RETVAL
90