rc.shutdown revision 96830
1#!/bin/sh
2#
3# Copyright (c) 1997  Ollivier Robert
4# All rights reserved.
5#
6# Redistribution and use in source and binary forms, with or without
7# modification, are permitted provided that the following conditions
8# are met:
9# 1. Redistributions of source code must retain the above copyright
10#    notice, this list of conditions and the following disclaimer.
11# 2. Redistributions in binary form must reproduce the above copyright
12#    notice, this list of conditions and the following disclaimer in the
13#    documentation and/or other materials provided with the distribution.
14#
15# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
16# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18# ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
19# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
21# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
25# SUCH DAMAGE.
26#
27# $FreeBSD: head/etc/rc.shutdown 96830 2002-05-18 00:26:10Z gordon $
28#
29
30# Site-specific closing actions for daemons run by init on shutdown,
31# or before going single-user from multi-user.
32# Output and errors are directed to console by init, and the
33# console is the controlling terminal.
34
35stty status '^T'
36
37# Set shell to ignore SIGINT (2), but not children;
38# shell catches SIGQUIT (3) and returns to single user after fsck.
39trap : 2
40trap : 3	# shouldn't be needed
41
42HOME=/
43PATH=/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/sbin
44export HOME PATH
45
46# If there is a global system configuration file, suck it in.
47#
48if [ -r /etc/defaults/rc.conf ]; then
49	. /etc/defaults/rc.conf
50	source_rc_confs
51elif [ -r /etc/rc.conf ]; then
52	. /etc/rc.conf
53fi
54
55# reverse_list list
56#	print the list in reverse order
57#
58reverse_list()
59{
60	_revlist=
61	for _revfile in $*; do
62		_revlist="$_revfile${script_name_sep}$_revlist"
63	done
64	echo $_revlist
65}
66
67# Write some entropy so the rebooting /dev/random can reseed
68#
69case ${entropy_file} in
70[Nn][Oo] | '')
71	;;
72*)
73	echo -n 'Writing entropy file:'
74	rm -f ${entropy_file}
75	oumask=`umask`
76	umask 077
77	if touch ${entropy_file} ; then
78		entropy_file_confirmed="${entropy_file}"
79	else
80		# Try this as a reasonable alternative for read-only
81		# roots, diskless workstations, etc.
82		rm -f /var/db/entropy
83		if touch /var/db/entropy ; then
84			entropy_file_confirmed=/var/db/entropy
85		fi
86	fi
87	case ${entropy_file_confirmed} in
88	'')
89		echo ' ERROR - entropy file write failed'
90		;;
91	*)
92		dd if=/dev/random of=${entropy_file_confirmed} \
93		   bs=4096 count=1 2> /dev/null
94		echo '.'
95		;;
96	esac
97	umask ${oumask}
98	;;
99esac
100
101# Check if /var/db/mounttab is clean.
102case $1 in
103reboot)
104	if [ -f /var/db/mounttab ]; then
105		rpc.umntall
106	fi
107	;;
108esac
109
110echo -n 'Shutting down daemon processes:'
111
112# for each valid dir in $local_startup, search for init scripts matching *.sh
113case ${local_startup} in
114[Nn][Oo] | '')
115	;;
116*)
117	slist=""
118	if [ -z "${script_name_sep}" ]; then
119		script_name_sep=" "
120	fi
121	for dir in ${local_startup}; do
122		if [ -d "${dir}" ]; then
123			for script in ${dir}/*.sh; do
124				slist="${slist}${script_name_sep}${script}"
125			done
126		fi
127	done
128	script_save_sep="$IFS"
129	IFS="${script_name_sep}"
130	for script in `reverse_list ${slist}`; do
131		if [ -x "${script}" ]; then
132			(set -T
133			trap 'exit 1' 2
134			${script} stop)
135		fi
136	done
137	IFS="${script_save_sep}"
138	echo '.'
139	;;
140esac
141
142# Insert other shutdown procedures here
143
144# Saving firewall state tables should be done last
145echo -n 'Saving firewall state tables:'
146
147# Save IP-filter state tables
148case ${ipfs_enable} in
149[Yy][Ee][Ss])
150	echo -n ' ipfs'
151	${ipfs_program:-/sbin/ipfs} -W ${ipfs_flags}
152	;;
153esac
154
155echo '.'
156exit 0
157